【问题标题】:Google Apps Script. Setting an active sheet (focus) in another spreadsheet.Google Apps 脚本。在另一个电子表格中设置活动工作表(焦点)。
【发布时间】:2018-03-24 04:56:40
【问题描述】:

我有这个脚本,它可以删除另一个电子表格中除第一张以外的所有表格。它工作正常,但如果在另一个电子表格中焦点不在第一张表中,则另一个电子表格崩溃并且必须重新加载。没问题,一切都还可以,但是很麻烦。在删除除第一张以外的所有表格之前,如何使第一张表格具有输入焦点?

          var numsh = dest_ss.getNumSheets();
          for (var i = 0; i < numsh-1; i++) {
          dest_ss.deleteSheet(dest_ss.getSheets()[dest_ss.getNumSheets() - 1]);
          }

【问题讨论】:

  • 因此您有 2 个单独的电子表格,并且您从电子表格 2 中删除了电子表格 1 上除第一张表格之外的所有表格。但如果有人正在查看将在电子表格 1 上删除的表格,则电子表格 1 chrash,必须重新加载。并且您希望将焦点从删除工作表设置到第一张工作表以避免那些崩溃。我说的对吗?
  • 是的,这是正确的。从电子表格 1 中,我将删除电子表格 2 的第一张以外的所有表格。

标签: google-apps-script


【解决方案1】:

您应该倒数,而不是更新索引值。 这样做你就不需要关心活动表了。

试试这样:

var numsh = dest_ss.getNumSheets();
for (var i = numsh-1; i >0; i--) {
  dest_ss.deleteSheet(dest_ss.getSheets()[i]);
}

【讨论】:

  • 感谢您,但它仍然给出相同的错误:-“无法加载文件,请尝试再次加载或发送错误报告。”如果我手动选择第一张纸,则没有错误。
  • 我想我会使用你的代码。它看起来更有效率。非常感谢。我只需要记住在运行之前选择第一张工作表。
  • 根据我的经验,在每次 deleteSheet 调用之间添加一个小暂停以防止浏览器页面冻结是个好主意,我使用 Utilities.sleep(400); 使用 400 毫秒睡眠。如果它也能解决你的问题,也许你可以试试。
  • 请看这篇描述这个特定方面的帖子:stackoverflow.com/questions/11142109/… btw,它使用另一种方法来删除工作表,因为在我写它的时候你使用的方法不存在然而;)
  • 400 毫秒的暂停解决了这个问题。非常感谢。我尝试了 200 毫秒,但仍然出现错误。
【解决方案2】:

试试这个代码

var numsh = dest_ss.getNumSheets();
for (var i = 0; i < numsh; i++){
       if(dest_ss.getSheets()[i].getName()!= "YOUR SHEET NAME WHICH YOU DONOT WANT TO DELETE"){
          dest_ss.deleteSheet(dest_ss.getSheets()[i]);
       }
 }

【讨论】:

  • 我收到“无法调用未定义的方法“getName”的错误。”在这一行:- if(dest_ss.getSheets()[i].getName()!= "Info"){
  • 你不能放置对用户有害的代码......如果他们没有发现 deleteSheet 选项怎么办?
【解决方案3】:

您可以使用

使第一张工作表成为活动工作表
dest_ss.setActiveSheet(dest_ss.getSheets()[0]);

【讨论】:

  • 我想我已经尝试过了,但仍然收到错误“无法加载文件,请尝试再次加载或发送错误报告。”刚刚又试了一次,还是一样的错误。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2021-06-27
  • 1970-01-01
  • 2020-05-21
  • 1970-01-01
  • 2013-11-16
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多