如何在Google电子表格中自动添加时间戳

时间:2014-10-15 04:11:13

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

我的Google电子表格中有一张包含5个单元格的工作表,前3个只包含单词,而最后2个包含时间,特别是时间戳。

cell 1 = data
cell 2 = data
cell 3 = data
cell 4 = time start
cell 5 = time ended

现在,我想要的是当为单元格1提供数据时,时间戳将自动出现在单元格4中。当向单元格2和单元格3提供数据时,时间戳将是单元格5的新值。 / p>

我的朋友给我一个代码,应该粘贴在脚本编辑器中:

function readRows() {
  var sheet = SpreadsheetApp.getActiveSheet();
  var rows = sheet.getDataRange();
  var numRows = rows.getNumRows();
  var values = rows.getValues();

for (var i = 0; i <= numRows - 1; i++) {
  var row = values[i];
  Logger.log(row);
 }
};

function onOpen() {
 var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
 var entries = [{
 name : "Read Data",
 functionName : "readRows"
}];
spreadsheet.addMenu("Script Center Menu", entries);
};
function timestamp() {
return new Date()
}

并且此代码粘贴在=IF(B6="","",timestamp(B6))单元格4中,而这个=IF(D6="","",timestamp(C6&B6))位于单元格5中。在他的示例跟踪器中,它的工作正常。但是当我把它复制到我的时候,单元格4和单元格5中的输出是今天的日期,而不是时间。

谁能帮助我吗?为什么输出日期而不是时间?

3 个答案:

答案 0 :(得分:7)

如果有帮助,您可以参考此tutorial。 在脚本代码中,更改

var timestamp_format = "MM-dd-yyyy"; // Timestamp Format.

var timestamp_format = "MM-dd-yyyy hh:mm:ss"; // Timestamp Format.

这应该可以帮到你。

答案 1 :(得分:5)

我刚遇到此问题,并修改了Internet Geeks提供的代码。

他们的代码通过更新指定的列来工作,时间戳插入另一个指定列的同一行。

我更改的是我将日期和时间分开,因为时间戳是字符串,而不是日期格式。我的方式对于生成图表很有用。

它的工作原理是指定要跟踪更改的列,然后分别为日期和时间创建upDate和upTime列。

function onEdit(event) {
  var timezone = "GMT+1";
  var date_format = "MM/dd/yyyy";
  var time_format = "hh:mm";

  var updateColName = "Резултат";

  var DateColName = "upDate";
  var TimeColName = "upTime";

  var sheet = event.source.getActiveSheet(); // All sheets
  // var sheet = event.source.getSheetByName('Test'); //Name of the sheet where you want to run this script. 

  var actRng = event.source.getActiveRange();
  var editColumn = actRng.getColumn();
  var index = actRng.getRowIndex();
  var headers = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues();

  var dateCol = headers[0].indexOf(DateColName);
  var timeCol = headers[0].indexOf(TimeColName);

  var updateCol = headers[0].indexOf(updateColName);
  updateCol = updateCol + 1;

  if (dateCol > -1 && timeCol > -1 && index > 1 && editColumn == updateCol) {
    // only timestamp if 'Last Updated' header exists, but not in the header row itself! 

    var cellDate = sheet.getRange(index, dateCol + 1);
    var cellTime = sheet.getRange(index, timeCol + 1);

    var date = Utilities.formatDate(new Date(), timezone, date_format);
    var time = Utilities.formatDate(new Date(), timezone, time_format);

    cellDate.setValue(date);
    cellTime.setValue(time);
  }
}

希望这有助于人们。

答案 2 :(得分:0)

基于Internet Geeks的代码,我制作了一个稍有不同的版本

为了支持多个命名工作表,并且由于Google Sheets Script当前不支持Array.prototype.includes(),我加入了提到的here

此外,在我的版本中,时间戳记标记该行单元格的创建日期,而不是此处提供的其他脚本中的最后更新日期。

function onEdit(event) {
  var sheetNames = [
    'Pounds £', 
    'Euros €'
  ]
  var sheet = event.source.getActiveSheet();
  if (sheetNames.includes(sheet.getName())){
    var timezone = "GMT";
    var dateFormat = "MM/dd/yyyy";
    var updateColName = "Paid for ...";
    var dateColName = "Date";

    var actRng = sheet.getActiveRange();
    var editColumn = actRng.getColumn();
    var rowIndex = actRng.getRowIndex();
    var headers = sheet.getRange(1, 1, 1, sheet.getLastColumn()).getValues();
    var dateCol = headers[0].indexOf(dateColName) + 1;
    var updateCol = headers[0].indexOf(updateColName) + 1;
    var dateCell = sheet.getRange(rowIndex, dateCol);
    if (dateCol > 0 && rowIndex > 1 && editColumn == updateCol && dateCell.isBlank())
    {
      dateCell.setValue(Utilities.formatDate(new Date(), timezone, dateFormat));
    }
  }
}

// https://stackoverflow.com/a/51774307/349169
// https://tc39.github.io/ecma262/#sec-array.prototype.includes
if (!Array.prototype.includes) {
  Object.defineProperty(Array.prototype, 'includes', {
    value: function(searchElement, fromIndex) {

      if (this == null) {
        throw new TypeError('"this" is null or not defined');
      }

      // 1. Let O be ? ToObject(this value).
      var o = Object(this);

      // 2. Let len be ? ToLength(? Get(O, "length")).
      var len = o.length >>> 0;

      // 3. If len is 0, return false.
      if (len === 0) {
        return false;
      }

      // 4. Let n be ? ToInteger(fromIndex).
      //    (If fromIndex is undefined, this step produces the value 0.)
      var n = fromIndex | 0;

      // 5. If n ≥ 0, then
      //  a. Let k be n.
      // 6. Else n < 0,
      //  a. Let k be len + n.
      //  b. If k < 0, let k be 0.
      var k = Math.max(n >= 0 ? n : len - Math.abs(n), 0);

      function sameValueZero(x, y) {
        return x === y || (typeof x === 'number' && typeof y === 'number' && isNaN(x) && isNaN(y));
      }

      // 7. Repeat, while k < len
      while (k < len) {
        // a. Let elementK be the result of ? Get(O, ! ToString(k)).
        // b. If SameValueZero(searchElement, elementK) is true, return true.
        if (sameValueZero(o[k], searchElement)) {
          return true;
        }
        // c. Increase k by 1. 
        k++;
      }

      // 8. Return false
      return false;
    }
  });
}