zon*_*ono 1 google-apps-script google-bigquery
我想从 BigQuery.Jobs.query 的响应中获取 JSON 字符串。有什么简单的方法吗?
谷歌应用脚本
var request = {
query: 'SELECT TOP(word, 300) AS word, COUNT(*) AS word_count ' + 'FROM publicdata:samples.shakespeare WHERE LENGTH(word) > 10;'
};
var queryResults = BigQuery.Jobs.query(request, projectId);
Run Code Online (Sandbox Code Playgroud)
我想从中获取 JSON 文本 queryResults
[
{
"word": "counterfeit",
"word_count": "28"
},
{
"word": "remembrance",
"word_count": "24"
},
{
"word": "countenance",
"word_count": "24"
},
Run Code Online (Sandbox Code Playgroud)
感谢 Henrique Abreu。
var request = {
query: 'SELECT TOP(word, 300) AS word, COUNT(*) AS word_count ' + 'FROM publicdata:samples.shakespeare WHERE LENGTH(word) > 10;'
};
var queryResults = BigQuery.Jobs.query(request, projectId);
Logger.log(parseSimpleResults(queryResults));
[
{
word_count=28,
word=counterfeit
},
{
word_count=24,
word=remembrance
}
]
Run Code Online (Sandbox Code Playgroud)
我没有用更多的 BigQuery 查询结果对此进行测试,但它应该适用于“简单”的结果。
function parseSimpleResults(results) {
var names = results.schema.fields.map(function(field){ return field.name; });
return results.rows.map(function(row) {
var obj = {};
for( var i = 0, len = names.length; i < len; ++i ) {
obj[names[i]] = row.f[i].v;
}
return obj;
});
}
Run Code Online (Sandbox Code Playgroud)
只需将您的queryResults变量传递给它,您就会得到漂亮的对象数组。
| 归档时间: |
|
| 查看次数: |
555 次 |
| 最近记录: |