appscript+bigquery+googlesheets卡顿和长时间更新文档
创始人
2024-11-10 06:30:32
0

1、使用App Script编写脚本来优化查询。通过使用App Script,可以将大数据量查询分段,并使用锁定以减少带宽占用量。

以下是使用App Script查询BigQuery并将结果写入Google Sheets的代码示例:

function runQuery() {
  var projectId = 'YOUR_PROJECT_ID';
  var request = {
    query: 'SELECT * FROM `bigquery-public-data.samples.gsod` LIMIT 10;'
  };
  var queryResults = BigQuery.Jobs.query(request, projectId);
  var jobId = queryResults.jobReference.jobId;

  // Check on status of the Query Job.
  var sleepTimeMs = 500;
  while (!queryResults.jobComplete) {
    Utilities.sleep(sleepTimeMs);
    sleepTimeMs *= 2;
    queryResults = BigQuery.Jobs.getQueryResults(projectId, jobId);
  }

  // Get all the rows of results.
  var rows = queryResults.getRows();

  // Print column headers.
  var sheet = SpreadsheetApp.getActiveSheet();
  var headers = queryResults.getSchema().getFields();
  for (var i = 0; i < headers.length; i++) {
    sheet.getRange(1, i + 1).setValue(headers[i].name);
  }

  // Print rows of results.
  for (var rowNum = 0; rowNum < rows.length; rowNum++) {
    var values = rows[rowNum].f;
    for (var colNum = 0; colNum < headers.length; colNum++) {
      var cell = sheet.getRange(rowNum + 2, colNum + 1);
      cell.setValue(values[colNum].v);
    }
  }
}

2、使用Google Sheets的数据提取功能。将最近查询的结果存储到Google Sheets中,然后在新的查询中引用这些结果。

下面是一个使用数据提取功能的示例,它将BigQuery中存储的数据提取到Google Sheets中,并通过App Script将数据刷新成最新的数据:

function refreshData() {
  var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Sheet1');

  // Get the current values.
  var currentValues = sheet.getDataRange().getValues();

  // Fetch the latest data from your BigQuery table.
  // `newData` should be a `2D array` of values.
  var newData = fetchNewData();

  // Replace the `currentValues` with `newData` if `currentValues` isn't empty.
  if (currentValues.length > 1) {

相关内容

热门资讯

记者揭秘!智星菠萝辅助(透视辅... 记者揭秘!智星菠萝辅助(透视辅助)拱趴大菠萝辅助神器,扑克教程(有挂细节);模式供您选择,了解更新找...
一分钟揭秘!约局吧能能开挂(透... 一分钟揭秘!约局吧能能开挂(透视辅助)hhpoker辅助靠谱,2024新版教程(有挂教学);约局吧能...
透视辅助!wepoker模拟器... 透视辅助!wepoker模拟器哪个好用(脚本)hhpoker辅助挂是真的,科技教程(有挂技巧);囊括...
透视代打!hhpkoer辅助器... 透视代打!hhpkoer辅助器视频(辅助挂)pokemmo脚本辅助,2024新版教程(有挂教程);风...
透视了解!约局吧德州真的有透视... 透视了解!约局吧德州真的有透视挂(透视脚本)德州局HHpoker透视脚本,必胜教程(有挂分析);亲,...
六分钟了解!wepoker挂底... 六分钟了解!wepoker挂底牌(透视)德普之星开辅助,详细教程(有挂解密);德普之星开辅助是一种具...
9分钟了解!wpk私人辅助(透... 9分钟了解!wpk私人辅助(透视)hhpoker德州透视,插件教程(有挂教学);风靡全球的特色经典游...
推荐一款!wepoker究竟有... 推荐一款!wepoker究竟有透视(脚本)哈糖大菠萝开挂,介绍教程(有挂技术);囊括全国各种wepo...
每日必备!wepoker有人用... 每日必备!wepoker有人用过(脚本)wpk有那种辅助,线上教程(有挂规律);wepoker有人用...
玩家必备教程!wejoker私... 玩家必备教程!wejoker私人辅助软件(脚本)哈糖大菠萝可以开挂,可靠技巧(有挂神器)申哈糖大菠萝...