javascript - 通过搜索/比较自动增加值并匹配 Google Sheets 脚本中的两列

标签 javascript google-apps-script google-sheets

我目前必须手动输入 Sheet1 的 B 列,但我想在每次脚本运行时自动递增它。

我正在使用 Google 表格脚本。

这部分正在工作。

它是如何工作的: Sheet2列A是从Sheet1列A导入的下拉列表

如果 Sheet2 列 B 是今天日期的周年纪念日,那么 Sheet2 列 F 会自动“重置”

然后,工作脚本删除工作表 2 中 F 为“重置”的行,并在底部为每行添加新行

当前正在使用此脚本

function writeupReset() {
  var ss = SpreadsheetApp.getActiveSpreadsheet(); 

  var s = ss.getSheetByName('Sheet2');
  var r = s.getRange('C:C');
  var v = r.getValues();

  for(var i=v.length-1;i>=0;i--){
    if(v[0,i]=='reset'){
      s.insertRowsAfter(251,1);
      s.deleteRow(i+1);
    }
  }
}

使用今天日期的工作位示例 - 6/2/20

      Sheet1                Sheet2  (before script)           Sheet2  (after script)

      A      B              A       B         C               A       B         C
  |---------------|     |-------------------------|       |-------------------------|
1 | name | resets |   1 | name  |  date   | delet |     1 | name  |  date   | delet |
  |---------------|     |-------------------------|       |-------------------------|
2 | bill |   1    |   2 | bill  | 6/2/19  | reset |     2 | alex  |  9/5/19 |       |
  |---------------|     |-------------------------|       |-------------------------|
3 | mark |   5    |   3 | alex  |  9/5/19 |       |     3 | adam  | 11/6/19 |       |
  |---------------|     |-------------------------|       |-------------------------|
4 | holy |   2    |   4 | adam  | 11/6/19 |       |     4 | tony  | 12/1/19 |       |
  |---------------|     |-------------------------|       |-------------------------|
5 | tony |   0    |   5 | mark  | 6/2/19  | reset |     5 |       |         |       |
  |---------------|     |-------------------------|       |-------------------------|
6 | alex |   2    |   6 | tony  | 12/1/19 |       |     6 |       |         |       |
  |---------------|     |-------------------------|       |-------------------------|
7 | june |   1    |   7 |       |         |       |     7 |       |         |       |
  |---------------|     |-------------------------|       |-------------------------|
8 | jack |   0    |   to 252 rows (last two hidden)     to 252 rows (last two hidden)
  |---------------|   
9 | adam |   2    |   
  |---------------|   

那么,当脚本删除 Sheet1 中的那些“重置”行时,如何编辑脚本以自动递增 Sheet1 列 B?

最佳答案

我相信您的目标如下。

  • 当脚本删除“Sheet2”中具有 reset 的行时,您希望增加“Sheet1”中名称相同的“B”列的值。
    • 在您的例子中,“Sheet2”的“A”列中包含相同的名称。
  • 您希望通过修改问题中的脚本来实现此目的。

对于这个,这个答案怎么样?

修改点:

  • 在这种情况下,需要知道“Sheet1”的值并将其与“Sheet2”的值进行比较。流程如下。
    1. 删除“Sheet2”中的行。
      • 此时,将创建一个包含已删除行信息的对象。
    2. 增加“Sheet1”中“B”列的值。
      • 使用该对象更新“B”列的值,并将更新后的值放入工作表中。

当以上几点反射(reflect)到您的脚本中时,它会变成如下所示。

修改后的脚本:

function writeupReset() {
  var ss = SpreadsheetApp.getActiveSpreadsheet();

  // 1. Delete rows in Sheet2.
  var s = ss.getSheetByName('Sheet2');
  var r = s.getRange('A1:C' + s.getLastRow());  // Modified
  var v = r.getValues();
  var obj = {};  // Added
  for(var i=v.length-1;i>=0;i--){
    if(v[i][2] == 'reset') {  // Modified
      s.insertRowsAfter(251,1);
      s.deleteRow(i+1);
      var name = v[i][0]  // Added
      obj[name] = obj[name] ? obj[name] + 1 : 1;  // Added
    }
  }

  // I added below script.
  // 2. Increase values of the column "B" in Sheet1.
  var sheet = ss.getSheetByName("Sheet1");
  var range = sheet.getRange("A2:B" + sheet.getLastRow());
  var values = range.getValues().map(([a, b]) => ([obj[a] ? b += obj[a] : b]));
  range.offset(0, 1, values.length, 1).setValues(values);
}

注意:

  • 在此修改后的脚本中,假设“Sheet1”中“A”列的每个值都是所有值中的唯一值。从你的问题中,我可以这样理解。
  • 如果“Sheet1”和“Sheet2”的工作表名称与您的实际情况不同,请修改。
  • 如果您的实际情况与问题中示例值的结构不同,则此修改后的脚本可能不起作用。所以请小心这一点。

引用文献:

关于javascript - 通过搜索/比较自动增加值并匹配 Google Sheets 脚本中的两列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62155943/

相关文章:

android-studio - 对于 ACTION_VIEW,Google 表格需要哪些信息?

javascript - 监控/调试 SignalR 数据

javascript - 使用两个变量查找数组值

charts - Google 电子表格 sheet.getCharts() 仅在打开电子表格时有效?

typescript - Vue + Typescript 网页在 GAS sidemenu 模板中不可见

date - apply FilterCriteria "whenDateEqualToAny(dates)"- 要解析的日期数组(日期)的正确形式是什么?

javascript - 如何将 newDataValidation() 代码块添加到我的 Google 应用程序脚本中

javascript - 通过子进程连接Java应用程序后如何在node.js中写入文件

javascript - 将值从 iframe 传递到不同域或端口的父级

google-apps-script - 无法部署可匿名访问的 Google Apps 脚本 webapp