【发布时间】:2014-03-27 02:05:09
【问题描述】:
我正在尝试使用应用脚本将 BigQuery 结果加载到 Google 电子表格中。这是我的代码
function runQuery() {
var projectId = 'xxxxx';
var request = {
query: 'select * from ASRLogs.LocationBasedClicks;'
};
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 the result.
var rows = queryResults.rows;
while (queryResults.pageToken) {
queryResults = BigQuery.Jobs.getQueryResults(projectId, jobId, {
pageToken: queryResults.pageToken
});
rows = rows.concat(queryResults.rows);
}
if (rows) {
var spreadsheet = SpreadsheetApp.create("BigQuery Results");
var sheet = spreadsheet.getActiveSheet();
// Append the headers
var headers = queryResults.schema.fields.map(function(field) {
return field.name;
});
sheet.appendRow(headers)
// Append the results.
var data = new Array(rows.length);
for (var i = 0; i < rows.length; i ++){
var cols = rows[i].f;
data[i] = new Array(cols.length);
for (var j =0; j < cols.length; j++){
data[i][j] = cols[j].v;
}
}
sheet.getRange(2,1,rows.length,headers.length).setValue(data);
Logger.log('Results spreadsheet created: %s', spreadsheet.getUrl());
} else {
Logger.log('No rows returned.')
}
}
我得到的错误是
错误:invalid_client
未找到 OAuth 客户端。
请求详情
- cookie_policy_enforce=false
- 范围=https://www.googleapis.com/auth/bigqueryhttps://www.googleapis.com/auth/spreadsheets
- response_type=code gsession
-redirect_uri=https://script.google.com/oauthcallback
- access_type=离线
- 批准提示=强制
- state=ACjPJvHwuS-sspO-j9b5vlH_Ul4VokI3QRANL-gwa7YWxz6-RFelZBuLQ2aiiGldHRgR89sMnvlgpsmSOnlquEY45oTt1IgZHWfoWq5e52Jf6l_G-5yPpPwCf40Dkv_JYR9welQPrQ
- client_id=734978265744@developer.gserviceaccount.com
- hl=zh
我错过了什么吗?我做了以下事情。
- 在 Google 服务中启用 BigQuery API
- 在项目的开发者控制台中启用 BigQuery。
【问题讨论】:
标签: google-apps-script google-bigquery