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) {

相关内容

热门资讯

第3分钟窍要!德扑之心免费透视... 第3分钟窍要!德扑之心免费透视(透视)一贯是有辅助下载(哔哩哔哩)该软件可以轻松地帮助玩家将德扑之心...
第七分钟阶段!hhpoker怎... 第七分钟阶段!hhpoker怎么破解(透视)竟然有辅助开挂(哔哩哔哩)该软件可以轻松地帮助玩家将hh...
九分钟秘籍!wepoker私人... 九分钟秘籍!wepoker私人局俱乐部辅助(透视)总是是有辅助下载(哔哩哔哩)1、这是跨平台的wep...
7分钟课程!wepoker究竟... 7分钟课程!wepoker究竟有没有透视(透视)切实是真的有辅助安装(哔哩哔哩)1、用户打开应用后不...
第三分钟教程书!wepoker... 第三分钟教程书!wepoker轻量版辅助(透视)果然有辅助教程(哔哩哔哩)该软件可以轻松地帮助玩家将...
六分钟大纲!wepoker插件... 六分钟大纲!wepoker插件辅助(透视)本来是有辅助透视(哔哩哔哩)运wepoker插件辅助辅助工...
第六分钟策略!拱趴大菠萝挂哪里... 第六分钟策略!拱趴大菠萝挂哪里(透视)好像是真的有辅助神器(哔哩哔哩)1、拱趴大菠萝挂哪里辅助软件下...
5分钟技法!wpk透视工作室(... 5分钟技法!wpk透视工作室(透视)切实是有辅助教程(哔哩哔哩)wpk透视工作室脚本下载中分为三种模...
8分钟阶段!wepoker透视... 8分钟阶段!wepoker透视脚本安卓(透视)其实有辅助下载(哔哩哔哩)1、wepoker透视脚本安...
3分钟法门!如何判断wpk辅助... 3分钟法门!如何判断wpk辅助软件的真假(透视)原来是真的有辅助教程(哔哩哔哩)1、起透看视 如何判...