【问题标题】:onOpen on specific Sheet in AppScriptonOpen 在 AppScript 中的特定工作表上
【发布时间】:2020-08-31 10:27:20
【问题描述】:

我有一个 onOpen 执行代码,但我希望它仅在打开特定工作表时执行(例如,在打开 Sheet1 时,onOpen 函数应该运行。)有人知道如何实现吗?

这正是我想要实现的目标:

  1. 打开电子表格时,检查活动工作表是否为 sheet1。如果它随后在该工作表中执行一个条件,如下所示:
onOpen()
{
    //If the active sheet is "Sheet1" then perform this:
    //Sheet Execution comes here.
}

但是上面的说法有问题:

onOpen 只会在工作表打开后检查。每次活动工作表为“Sheet1”时,我都想检查它。例如,最初用户打开电子表格,他们登陆到“Sheet1” 现在检查条件并显示输出,但是如果用户将选项卡更改为“Sheet2”然后返回到“Sheet1”怎么办。在这种情况下,onOpen() 将不会执行。我想在用户每次登陆或切换到“Sheet1”时进行检查。

现在是另一个场景:

使用onSelectionChange:

onSelectionCHange()
{
    //If the active sheet is "Sheet1" then perform this:
    //Sheet Execution comes here.
}

现在,每次用户切换到“Sheet1”时,这都会起作用,但问题是,即使用户切换到“Sheet1”中的不同单元格onSelectionChange 也会被触发,这又是不受欢迎的事情。我只想在每次选项卡/工作表更改为“Sheet1”时触发该功能,而不仅仅是在打开电子表格或更改任何选择单元格时触发。

【问题讨论】:

    标签: google-apps-script google-sheets


    【解决方案1】:

    解释:

    当您从 Sheet1 打开电子表格文件时,要在onOpen 函数内执行代码块,那么您可以构造以下 if 条件:

    function onOpen(e) {
    const as = e.source.getActiveSheet().getName();
      if (as == 'Sheet1'){
    //code you want to be executed when you open the spreadsheet from Sheet1
    }
    }
    

    缺点:

    onOpen 函数仅在您打开 电子表格 文件时执行。您不能只在工作表之间切换并期望 onOpen 起作用。


    解决方案:

    要在不同工作表之间切换时执行代码,您可以改用onSelectionChange(e)。当您从不同的工作表切换到Sheet1时,以下示例设置Sheet1的单元格A1的值:

    function onSelectionChange(e) {
      
    const as = e.source.getActiveSheet();
      if (as.getName() == 'Sheet1'){ 
        as.getRange('A1').setValue("This is Sheet1");
      }
    }
    

    这里是切换到Sheet1时执行代码的通用代码模板:

      function onSelectionChange(e) {
          
        const as = e.source.getActiveSheet();
          if (as.getName() == 'Sheet1'){ 
            // put your code here
          }
        }
    

    参考资料:

    【讨论】:

    • 如果您要切换电子表格,这会起作用吗?例如,目前我在 sheet1 上,所以第一次 onOpen 会起作用,但如果我在工作表之间切换,我认为这不会触发 onOpen?
    • @ShivamSahil 我刚刚更新了我的答案。 onOpen 函数仅在您打开电子表格时起作用,而不是在您在工作表之间切换时起作用。
    • 嗯,我明白了,谢谢...实际上我正在寻找在工作表之间切换时有效的东西。
    • @ShivamSahil 请查看我编辑的答案。解决方案部分。 :)
    • 我看到了您的解决方案...但没有解决我的问题,无论如何感谢您的参考。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2023-01-19
    • 2011-06-16
    • 1970-01-01
    • 2020-11-26
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多