Google 工作表根据单元格编号值添加行

Google Sheets Add row based on cell number value

我正在尝试制作一个 google sheet 脚本,它根据单元格值添加一行,基本上如果我在数量(D 列)中有 7 台笔记本电脑,我想要脚本如果通过数据验证将 H 列标记为 "Yes",则在下方添加 6 行。

我能够找到并做的只是复制该行但没有数据验证,我更愿意添加数据验证并可能在复制后将每个数量拆分为 1(而不是 7)。

`function autoDup() {
      var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
      var data = sheet.getDataRange().getValues();
     var newData = [];
     for(var n in data){
       newData.push(data[n]);
    if(!Number(data[n][3])){continue};// if column 3 is not a number then do nothing
      for(var c=1 ; c < Number(data[n][3]) ; c++){ // start from 1 instead of 0 because we have already 1 copy
      newData.push(data[n]);//store values
    }
  }
  sheet.getRange(1,1,newData.length,newData[0].length).setValues(newData).sort({column: 1, ascending: false});// write new data to sheet, overwriting old data
}`

希望有人能帮助我。 谢谢,

D 列包含数量和商品描述。如果 Column H = "Yes",您希望在 Col D 下方插入等于数量减一的行数。如果 H 列 <>“是,则不采取任何行动。


示例数据 - 之前


示例数据 -

之后


function so5925663201() {

  var ss = SpreadsheetApp.getActiveSpreadsheet();
  var sheetname = "59256632";
  var sheet = ss.getSheetByName(sheetname);

  var row = 7;

  // get value of Column H
  var colHValue = sheet.getRange(row,8).getValue();

  if (colHValue === "Yes"){
    //Logger.log("DEBUG: Col H = yes. do something")

    // get value of Column D
    var Value = sheet.getRange(row,4).getValue();
    var searchterm = "x";
    var indexOfFirst = Value.indexOf(searchterm);
    //Logger.log("DEBUG: the first instance of 'x' is "+indexOfFirst);

    // get the quantity and convert from a string to a number
    var qty = Value.substring(0, indexOfFirst);
    var qtynum = +qty;
    // var newtype = typeof qtynum; // DEBUG
    //Logger.log("DEBUG: the quantity is "+qtynum+", new type = "+newtype)

    // This inserts rows after 
    sheet.insertRowsAfter(row, qtynum-1);
  }
  else{
    //Logger.log("DEBUG: col H <> Yes. do nothing");
  }
}