其他分享
首页 > 其他分享> > android – Google表格API:如何按值查找行并更新其内容

android – Google表格API:如何按值查找行并更新其内容

作者:互联网

我正在开发一个使用Google电子表格作为数据库的Android应用程序.
应用程序应使用Sheets API v4在电子表格中获取GET,APPEND和UPDATE值.前两个函数工作正常但我更新特定行时遇到困难.我需要在它的第一列(“批次ID”)中找到一个具有特定值的行,并更新该行中的所有单元格.

这就是我的电子表格的样子.

现在我正在修改这样的行:

ValueRange response = this.mySheetsService.spreadsheets().
                values().get(spreadsheetId, range).execute();

List<List<Object>> values = response.getValues();
String rangeToUpdate;

Log.i(TAG, "all values in range: " + values.toString());

int i = 0;
if (values != null) {
    for (List row : values) {
        i += 1;
        if (row.get(0).equals(selectedBatchID)) {
            Log.i(TAG, "IT'S A MATCH! i= " + i);
            rangeToUpdate = "A" + (i + 1) + ":E" + (i + 1); //row to be updated
        }
    }
}
/*once I have the row that needs to be updated, I construct my new ValueRange requestbody and
*execute a values().update(spreadsheetId, rangeToUpdate , requestbody) request.
*/

这实际上工作正常,但我认为这是一个丑陋的解决方案,我相信那里有一个更好的解决方案.

我已经阅读了Sheets API文档,并熟悉了诸如batchUpdateByDataFilter,DataFilterValueRange或DeveloperMetadata等概念,我觉得我应该将这些功能用于我想要实现的目标,但我无法将它们放在一起而且我不能找到任何例子.

有人可以告诉我或帮助我了解如何使用这些Shee​​ts V4功能吗?

谢谢.

解决方法:

我有完全相同的问题,似乎到目前为止(2018年3月)Sheets v4 API不允许按值搜索,返回单元格地址.我在StackOverflow上找到的解决方案是使用公式.每次要按值查找地址时,都可以在任意工作表中创建公式,然后删除公式.如果您不想每次都删除公式,则许多人更喜欢在更安全的地方创建,例如隐藏的工作表.

>创建隐藏的工作表LOOKUP_SHEET(spreadsheetId是您的电子表格ID):

POST https://sheets.googleapis.com/v4/spreadsheets/spreadsheetId:batchUpdate

{
 "requests": [
  {
   "addSheet": {
    "properties": {
     "hidden": true,
     "title": "LOOKUP_SHEET"
    }
   }
  }
 ]
}

>在隐藏工作表的A1单元格中创建一个公式,在MySheet1工作表中搜索“搜索值”,然后返回该行:

PUT https://sheets.googleapis.com/v4/spreadsheets/spreadsheetId/values/LOOKUP_SHEET!A1?includeValuesInResponse=true&responseValueRenderOption=UNFORMATTED_VALUE&valueInputOption=USER_ENTERED&fields=updatedData

{
 "range": "LOOKUP_SHEET!A1",
 "values": [
  [
   "=MATCH("Search value", MySheet1!A:A, 0)"
  ]
 ]
}

响应将如下所示:

{
 "updatedData": {
  "range": "LOOKUP_SHEET!A1",
  "majorDimension": "ROWS",
  "values": [
   [
    3
   ]
  ]
 }
}

默认情况下,主要维度为ROWS. MATCH()返回A列中的相对行,如果没有提供行ID,则此位置实际上是绝对的.或者,您可能希望使用更可靠的调用,例如= ROW(间接(地址(匹配(“搜索值”,A:A,0),1))).如果工作表中有空格,请将其用单引号括起来.如果您要搜索号码,请确保不要将其括在引号中.

标签:android,google-api,google-sheets,google-sheets-api
来源: https://codeday.me/bug/20190928/1827427.html