使用 Google 表格导入 XML 并每分钟自动刷新

Seb*_*Seb 1 google-sheets google-apps-script google-sheets-importxml

我有下面的脚本,它在名为价格的谷歌表中导入一些 XML 数据。一切正常,只是我设置了一个时间驱动的触发器每分钟运行一次,但数据不会更新。

  • 触发器似乎工作正常,因为我可以看到每分钟更新一次上次运行时间。
  • 调用 XML 数据的脚本工作正常,因为我可以看到电子表格中填充的数据。
  • XML 提要也工作正常,因为我可以看到每分钟更新一次的时间,也有一个 cron 工作。
  • 我只有这个功能作为一个项目。

    function getData() {
      var sheetName = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("prices");
      var queryString = Math.random();
      var cellFunction = '=ImportXML("http://myxmldata.com/data-xml.php","//data/date")';
      sheetName.getRange('A2').setValue(cellFunction);
    } 
    
    Run Code Online (Sandbox Code Playgroud)

    那么怎么了?

Seb*_*Seb 5

这是我解决问题的方法:

在您的电子表格上,转到顶部菜单 > 单击工具 > 然后单击脚本编辑器并添加以下脚本:

这是调用您的数据(例如 XML)的脚本。请使用您自己的信息更新脚本。YOUR-SHEET-NAME,是选项卡名称,例如“价格”。

function getData() {
  var sheetName = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("YOUR- 
  SHEET-NAME");
  var queryString = Math.random();
  var cellFunction = '=ImportXML("https://yoururl-xml.php","//trade/price")';  

  var range = sheetName.getRange('A2');

  range.clearContent();  // You can also use range.setFormula("");
  SpreadsheetApp.flush();
  range.setFormula(cellFunction);
  }
Run Code Online (Sandbox Code Playgroud)

在该脚本下方,添加以下脚本,此页面上的更多信息:定期刷新 IMPORTXML() 电子表格函数

YOUR-SHEET-ID 是电子表格 url 中的长数字,例如 1YTB12xSTMSNdoT_S1U67MtOUDTf6n4OL2tJLnTNAXYZ

function RefreshImports() {
  var lock = LockService.getScriptLock();
  if (!lock.tryLock(5000)) return;             // Wait up to 5s for previous refresh to end.

  var id = "YOUR-SHEET-ID";
  var ss = SpreadsheetApp.openById(id);
  var sheet = ss.getSheetByName("YOUR-SHEET-NAME");
  var dataRange = sheet.getDataRange();
  var formulas = dataRange.getFormulas();
  var content = "";
  var now = new Date();
  var time = now.getTime();
  var re = /.*[^a-z0-9]import(?:xml|data|feed|html|range)\(.*/gi;
  var re2 = /((\?|&)(update=[0-9]*))/gi;
  var re3 = /(",)/gi;

  for (var row=0; row<formulas.length; row++) {
    for (var col=0; col<formulas[0].length; col++) {
      content = formulas[row][col];
      if (content != "") {
        var match = content.search(re);
        if (match !== -1 ) {
          // import function is used in this cell
          var updatedContent = content.toString().replace(re2,"$2update=" + time);
          if (updatedContent == content) {
            // No querystring exists yet in url
            updatedContent = content.toString().replace(re3,"?update=" + time + "$1");
          }
          // Update url in formula with querystring param
          sheet.getRange(row+1, col+1).setFormula(updatedContent);
        }
      }
    }
  }

  // Done refresh; release the lock.
  lock.releaseLock();

}
Run Code Online (Sandbox Code Playgroud)

这是两个脚本的屏幕截图:

在此处输入图片说明

然后添加计时器,转到顶部菜单单击时钟并添加触发器。确保选择正确的函数,即 RefreshImports。

在此处输入图片说明

在此处输入图片说明

完毕!