繁体   English   中英

我想通过谷歌电子表格脚本从许多工作表中的一些工作表中更改单元格值

[英]I want change cell values from some sheet in many sheet by google spread sheet script

function UpdateCell()
{
  const NotationRange = "J1";
  const ss = SpreadsheetApp.getActiveSpreadsheet();
  const sheets = ss.getSheets();
  const year = 2020;
  sheets.forEach
  (
    (sheet) => 
    { const sheetName = sheet.getName();
       { sheet.getRange(NotationRange).setValue(year+'.'+sheetName);
       }
    }
  )
}

在谷歌电子表格脚本中

上面的代码工作得很好而且很快,但是它改变了所有的工作表

工作表名称有规则。 所以可以区分

我想要的是更改工作表名称包含的特定工作表中的单元格值 [周]

在我的工作表名称中是 [Reference],[01.01],[01.02],,,,[12.31],[week01],[week02],,,[week53]

所以我尝试但失败了..

function UpdateCell()
{
  const NotationRange = "B2:D5"
  const ss = SpreadsheetApp.getActiveSpreadsheet();
  const sheets = ss.getSheets();
  const year = 2020
  const checkDailyWord = ".";
  const checkWeekWord = "week";
  var DC = new RegExp('\\b' + checkDailyWord + '\\b');
  var WC = new RegExp('\\b' + checkWeekWord + '\\b');
  sheets.forEach
  (
    (sheet) => 
    { const sheetName = sheet.getName();
       if( DC.sheetName == 1 )
       { sheet.getRange(NotationRange).setValue(year+'.'+sheetName);
       }
       if( WC.sheetName == 1 )
       { sheet.getRange(NotationRange).setValue(year+'week'+sheetName);
       }
    }
  )
}

修改点:

  • new RegExp没有sheetName的属性。 Ref这样,总是返回undefined的。 我认为这可能是您的问题的原因。
  • 在您的情况下,我认为includes可用于 if 语句。

当以上几点反映到您的脚本时,它变成如下。

修改后的脚本:

function UpdateCell() {
  const NotationRange = "B2:D5"
  const ss = SpreadsheetApp.getActiveSpreadsheet();
  const sheets = ss.getSheets();
  const year = 2020
  const checkDailyWord = ".";
  const checkWeekWord = "week";
  sheets.forEach(sheet => {
    const sheetName = sheet.getName();
    if (sheetName.includes(checkDailyWord) && !sheetName.includes(checkWeekWord)) {
      sheet.getRange(NotationRange).setValue(year+'.'+sheetName);
    } else if (!sheetName.includes(checkDailyWord) && sheetName.includes(checkWeekWord)) {
      sheet.getRange(NotationRange).setValue(year+'week'+sheetName);
    }
  });
}
  • 运行此修改后的脚本时,在示例表名称01.01,01.02,12.31week01,week02,week53中运行sheet.getRange(NotationRange).setValue(year+'.'+sheetName)sheet.getRange(NotationRange).setValue(year+'week'+sheetName) ,分别。

笔记:

  • 在此修改后的脚本中,根据您的示例工作表名称,它假定具有工作表名称的工作表同时包含week. 不使用。

参考:

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM