GAS脚本在合并后更改工作表中的日期和时间

时间:2018-06-13 09:02:13

标签: javascript google-apps-script google-sheets

我有一个列有几张日期的列,当我将这些表中的数据合并到另一个电子表格由于某种原因时,每个日期会增加10个小时。



function runTransferToMasterSheet() {
  var folder = DriveApp.getFolderById("folderID");
  var contents = folder.getFiles();
  var file; 
  var data;
  
  var sheetMaster = SpreadsheetApp.openByUrl('sheetURL').getSheets()[0];
  
  var range = sheetMaster.getRange("A2:G120000");
  range.clear();
  while(contents.hasNext()){
    file = contents.next();    
    var sheet = SpreadsheetApp.openById(file.getId()).getSheets()[0];
    
    // delete row with columns names
    sheet.deleteRow(1);

    var data = sheet.getDataRange().getValues();
    
    setDataToMaster(sheetMaster, sheet, data);
  }
  
}

function setDataToMaster(sheetMaster, sheet, data) {
  var sheetMaster = sheetMaster; 
  var sheet = sheet;
  var startRow = 1; 
  var data = data;
  
  if (sheetMaster.getDataRange().getValue() == null) {
    sheetMaster.getRange(2, 1, data.length, 7).setValues(data);
  } else {
    sheetMaster.getRange((sheetMaster.getLastRow() + 1), 1, data.length, 7).setValues(data);
  }
}




将合并其中一张纸张中的日期 6/13/2018 11:10:00

最终表格中的日期 6/13/2018 21:10:00

1 个答案:

答案 0 :(得分:1)

由于某些原因,我合并的工作表(我使用一些api获得它们)的时区错误,所以决定在合并使用之前:

mySpreadSheet.setSpreadsheetTimeZone(Session.getScriptTimeZone());