本文介绍了Apps脚本,将工作表范围转换为Blob的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

背景:我正在尝试从Google表格上传单个数据行,并将其附加到BigQuery表中.

Background:I'm trying to upload an individual row of data from a Google Sheet and append it to a BigQuery table.

方法:我一直在使用 https://developers.google.com/apps-script/advanced/bigquery 来执行此操作,但是我不是使用数据文件作为示例,而是使用自己的工作表以及来自特定行的数据:

Method: I've been using https://developers.google.com/apps-script/advanced/bigquery to do this, but instead of a file of data as the example is, I am using my own sheet with data from a specific row:

 var file = SpreadsheetApp.getActiveSpreadsheet();
  var currentSheet = file.getSheetByName(name);
  var lastRow = currentSheet.getLastRow()
   var lastC = currentSheet.getLastColumn()
   var rows = currentSheet.getRange(2,1,1,lastC).getValues();

行"是要导入到BQ的数据行.我尝试了很多事情,根据另一个 StackOverflow问题,"rowsCSV"使值的2D数组为CSV.

"rows" is the row of data to be imported to BQ. I've tried a multitude of things, and according to another StackOverflow question, "rowsCSV" makes the 2D array of values CSV.

  var rowsCSV = rows.join("\n");

 var data = rowsCSV.getBlob().setContentType('application/octet-stream');

问题:每次我运行该函数时,都会收到错误消息在对象Blob中找不到函数getBlob."或无法将数组转换为(class)[] []"或在对象中找不到函数getBlob"Tue May 16 2017 00:00:00 GMT + 0200(CEST),58072.4 ,,,,,,,,,, test,其中最后一位(" Tue May ..)是该行的实际数据

Problem: Every time I run the function, I get the error "Cannot find function getBlob in object Blob. " or, "Cannot convert Array to (class)[][]", or "Cannot find function getBlob in object Tue May 16 2017 00:00:00 GMT+0200 (CEST),58072.4,,,,,,,,,,,test ", where the last bit ("Tue May..") is the actual data of the row.

我在做什么错了?

推荐答案

数组没有 getBlob 方法.您将必须使用 Utilities.newBlob()从字符串中获取Blob.您可以在此处

There is no getBlob method for an array. You will have to use the Utilities.newBlob() to get your blob from a string. You can find the documentation on the same here

 var rowsCSV = rows.join("\n");
 var blob = Utilities.newBlob(rowsCSV, "text/csv")
 Logger.log(blob.getDataAsString())
 var data = blob.setContentType('application/octet-stream');

等效地,您可以这样做

var rowsCSV = rows.join("\n");
var data = Utilities.newBlob(rowsCSV, 'application/octet-stream')

这篇关于Apps脚本,将工作表范围转换为Blob的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

08-28 12:24
查看更多