我为一个包含大量工作表的电子表格编写了一个脚本。工作表完成后,将复制该工作表并将其设置为受保护。我希望我的脚本在 onEdit() 期间在任何不受保护的工作表上运行。有没有办法确定工作表是否受到保护?
下面是
一个使用 getProtections 的示例:
function onEdit(e) {
var sheet = e.source.getActiveSheet()
var protect = sheet.getProtections(SpreadsheetApp.ProtectionType.SHEET)
if (protect != "Protection") {
// Run your code here. For example:
SpreadsheetApp.getActiveSpreadsheet().getActiveSheet().getRange("A1").setValue("Unprotected");
}
}
创建一个名为 onEdit(e)
的函数,并使用电子表格getSheets()
方法可以访问所有工作表并确定它们是否具有 SHEET 的保护类型。如果他们这样做,那么只需立即返回,不要在onEdit(e)
中处理它们。 可以使用此代码e.source.getActiveSheet().getName()
确定当前工作表名称。