首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >简单的Google脚本运行速度异常缓慢

简单的Google脚本运行速度异常缓慢
EN

Stack Overflow用户
提问于 2022-02-04 04:08:16
回答 1查看 61关注 0票数 1

我正在构建一个Sheet数据库设置,有些代码运行得非常慢(有时,不是100% )。这个特别让我迷惑不解:

代码语言:javascript
运行
复制
function onEdit(e){
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var s = SpreadsheetApp.getActiveSheet();
  var rc = s.getActiveCell().getColumn();
  var rr = s.getActiveCell().getRow()
  var job = s.getRange(2,2).getDisplayValue();
  if (rc == 2 && rr == 2 && s.getName()=='Entry' && job != "") {
    s.getRange("C1").setValue("LOADING...");
    SpreadsheetApp.flush();
    var helperSheet = ss.getSheetByName("Helper");    
    var testVals = helperSheet.getRange("E1:E").getValues();
    var firstRow = testVals.filter(String).length+1;
    var workData = helperSheet.getRange("E3:J"+firstRow).getDisplayValues();
    s.getRange("C5:H").clearContent(); //tech to end time (work chart)
    s.getRange(5,3,firstRow-2,6).setValues(workData); //tech to end time (work chart)
    SpreadsheetApp.flush();
    s.getRange("C1").clearContent();    
  }
}

在我清理了一下之后,我让它在2-3秒的时间内正常完成,但有时(和100%的时间在我的客户方面),它的超时时间为30秒。你能看到我做错了什么吗?我知道它有太多的函数调用,但我已经尽可能地减少了这些调用。在这一点上,我唯一的想法是并发()调用是一个问题。我使用这些,以便“加载”尽早出现,并且只有在其他一切都完成后才会清除。没有它们,它只出现半秒钟。

任何帮助都将是很棒的,因为它可能有助于指导我的其他脚本,也运行缓慢。

此外,在阅读了其他运行/运行缓慢的脚本的各种其他答案之后,我遇到了使用可安装触发器的想法。有什么原因可以让我的脚本运行得更快吗?

更新:我意识到可以将加载文本add/delete调用移到if测试之外,从而删除刷新()调用。这样,编辑另一个单元格就可以同时添加和删除文本,这样用户就不会看到它。在我的电脑上,它现在运行得很快。然而,我的客户还没有测试过它。所以,我认为现在有两个问题:( 1) flush()真的让脚本慢了那么多吗?( 2)我的代码中还有什么愚蠢的事情可以使它成为slow...sometimes吗?

新的守则:

代码语言:javascript
运行
复制
function onEdit(e){
  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var s = SpreadsheetApp.getActiveSheet();
  var rc = s.getActiveCell().getColumn();
  var rr = s.getActiveCell().getRow()
  var job = s.getRange(2,2).getDisplayValue();
  s.getRange("C1").setValue("LOADING...");
  if (rc == 2 && rr == 2 && s.getName()=='Entry' && job != "") {
    var helperSheet = ss.getSheetByName("Helper");    
    var testVals = helperSheet.getRange("E1:E").getValues();
    var firstRow = testVals.filter(String).length+1;
    var workData = helperSheet.getRange("E3:J"+firstRow).getDisplayValues();
    s.getRange("C5:H").clearContent(); //tech to end time (work chart)
    s.getRange(5,3,firstRow-2,6).setValues(workData); //tech to end time (work chart)
  }
    s.getRange("C1").clearContent();    

}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-02-04 04:25:02

试试这个:

代码语言:javascript
运行
复制
function onEdit(e) {
  const sh = e.range.getSheet();
  const job = sh.getRange(2, 2).getDisplayValue();
  if (e.range.columnStart == 2 && e.range.rowStart == 2 && sh.getName() == 'Entry' && job != "") {
    sh.getRange("C1").setValue("LOADING...");
    let hsh = e.source.getSheetByName("Helper");
    let workData = hsh.getRange("E3:J" + hsh.getLastRow()).getDisplayValues();
    sh.getRange(5, 3, sh.getLastRow() - 4, 6).clearContent();
    sh.getRange(5, 3, workData.length, 6).setValues(workData);
  }
  sh.getRange("C1").clearContent();
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70981313

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档