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等概念,我觉得我应该将这些功能用于我想要实现的目标,但我无法将它们放在一起而且我不能找到任何例子.
有人可以告诉我或帮助我了解如何使用这些Sheets 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工作表中搜索“搜索值”,然后返回该行:
{
"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