有没有一种方法可以检查特定数据的列范围?

时间:2019-10-27 14:02:29

标签: if-statement google-apps-script google-sheets match

我有2本工作簿, 电子表格A具有多个相同形式的表格。

电子表格B记录包含电子表格A工作表中的单元格,每张工作表中的单行(日志)。

电子表格B中的第一列包含电子表格A中所有工作表的超链接。我需要检查电子表格B中的超链接列,如下所示: 如果A列中存在超链接, 检查Spreadsheet A索引中的下一张表++ 其他 在最后一行之后的一行中记录新数据

我的代码曾经具有clear()函数来从头开始向Spreadsheet B提交,但这在执行时间上效率不高。 我正在尝试操纵当前代码以手动检查现有记录,并根据此逻辑i ++ / submit new row。

您可以忽略所有缺少的代码行,因为我可以运行它,我只需要这样做的逻辑,因为我在Apps Script中并不先进。预先感谢您的帮助。


电子表格A-Sheet1 SpreadsheetA-sheet1


电子表格A-Sheet2 SpreadsheetA-sheet2


电子表格B

Workbook B Log


我希望if语句在工作簿B的“工作表”链接列上运行。...如果向工作簿A中添加工作表#3(图1&2),提交后,我要检查工作簿B的“工作表”链接日志(因为它是唯一的)(如果存在),i ++ ....如果不存在,则在日志中添加第3条记录。

for(var index = 2; index < WBA.length; index++) 
  {
    var Sheet   = "https://docs.google.com/spreadsheets/d/WBA ID/edit#gid=";
    var SID     = WBA[index].getSheetId();
    var SheetID = Sheet + SID;
    var Data    = WBB.getDataRange().getValues();

    for(var i = 0; i < Data.length; i++)
    {
      if(Data[i][1] == SheetID)
        i++

      else
      {

    var lastRow = WBB.getLastRow() + 1;

    var Sheets_ID   = new Array()

    Sheets_ID.push( [WBA[index].getSheetId()] )
           WBB.getRange(lastRow,1).setFormula('=hyperlink("https://docs.google.com/spreadsheets/d/WBA ID/edit#gid=' + Sheets_ID +'")');

    var PN_Source    = WBA[index].getRange(6,3,1,1).getValues();      //getRange(row number, column number, number of rows, number of columns)
    var SC_Source      = WBA[index].getRange(8,3,1,1).getValues();

1 个答案:

答案 0 :(得分:1)

尝试一下:

function checkForLink() {
  var ssB=SpreadsheetApp.getActive();
  var sh1=ssB.getActiveSheet();
  var rg1=sh1.getRange(1,1,1,4);
  var vA1=rg1.getValues()[0];
  var hObj={};
  vA1.forEach(function(el,i){if(el){hObj[el]=i;}});
  var linkA=sh1.getRange(2,hObj['Sheet Link']+1,sh1.getLastRow(),1).getValues().map(function(r){return r[0];});
  var ssA=SpreadsheetApp.openById('SSA ID');
  var shts=ssA.getSheets();
  shts.forEach(function(sh,i){
    var vA=sh.getRange(1,1,2,sh.getLastColumn()).getValues();
    var sObj={};
    vA[0].forEach(function(e,i){sObj[e]=i;});
    var shlink=Utilities.formatString('https://docs.google.com/spreadsheets/d/%s//edit#gid=%s',ssA.getId(),sh.getSheetId());
    if(linkA.indexOf(shlink)==-1) {
      sh1.appendRow([vA[1][sObj.date],vA[1][sObj.age],vA[1][sObj.name],shlink]);
    } 
  });
}