Google表格基于单元格号添加行

问题描述 投票:0回答:1

我正在尝试制作一个基于工作表值添加一行的google工作表脚本,基本上,如果我在7台笔记本电脑的“数量(D列)”中添加了六行,那么我希望该脚本在下方添加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
}`

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

google-apps-script google-sheets insert row google-apps
1个回答
0
投票

D列包含数量和商品说明。如果Column H =“ Yes”,则要在Col D下插入等于qty减一的行数。如果H列<>“是,则不执行任何操作。


样本数据-之前

Sample data before


样本数据-之后

Sampledataafter


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");
  }
}
© www.soinside.com 2019 - 2024. All rights reserved.