首页 > 解决方案 > 循环遍历谷歌工作表中的列和行以标记 gmail - 谷歌应用脚​​本

问题描述

我正在尝试使用工作表列标记 gmail 线程。代码本身很好,我已经使用单行进行了测试。例如,A2 (MessageID 1) 和 B2 (Label 1) 我让它成功地根据列标记 gmail 线程。

但是,现在我正在为循环而苦苦挣扎。

这是脚本

function myFunction() {

  var ss = SpreadsheetApp.getActiveSpreadsheet();
    var sheet2 = ss.getSheetByName("Sheet1")
    
    var range=sheet2.getRange('A2:A');
    var value =range.getValues();

    var range2=sheet2.getRange('B2:B');
    var value2 =range2.getValues();

  var i = 0; //count
  while ( value2[i][0] != "" && value2[i][0] != "#N/A" ) {
    
    let label = GmailApp.getUserLabelByName(value2[i]);
    if (!label) {label = GmailApp.createLabel(value2[i]);

    console.log("Get threads");
    var threads= GmailApp.getThreadById(value[i]);
    console.log("Add label");
    threads.addLabel(label);
    
    
    i++;
  }
return i;
}  
     
}

这是列的图像

列

这是测试表的链接

代码执行问题:

  1. 如果 include return i;,它只处理第一行而不循环其他行。
  2. 如果删除return i;执行永远不会停止。

我尝试过应用其他类型的循环,这可能是因为我不太精通循环,但这是迄今为止我能得到的最接近的。

那么有没有解决办法呢?

标签: google-apps-scriptgoogle-sheetsgmaillabel

解决方案


位于语句i++if- 因此,如果它正在处理的标签已经存在,它可能永远不会增加。

我假设你应该只有一个声明if()

if (!label) {
  label = GmailApp.createLabel(value2[i]);
}

然后你需要删除}代码中额外的下层。

此外,return 语句是多余的。

如果代码缩进正确,可能更容易看到发生了什么。


推荐阅读