gpt4 book ai didi

android - 谷歌表格 API : How to find a row by value and update it's content

转载 作者:IT老高 更新时间:2023-10-28 23:21:51 25 4
gpt4 key购买 nike

我正在开发一个使用 Google 电子表格作为数据库的 Android 应用程序。应用程序应使用 Sheets API v4 获取、追加和更新电子表格中的值。前两个功能工作正常,但我在更新特定行时遇到了困难。我需要在第一列(“批处理 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 文档并熟悉诸如 batchUpdateByDataFilterDataFilterValueRangeDeveloperMetadata 等概念,我觉得我应该将这些功能用于我想要实现的目标,但我无法将它们放在一起,也找不到任何示例。

谁能告诉我或帮助我了解如何使用这些 Sheets V4 功能?

谢谢。

最佳答案

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

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

发布 https://sheets.googleapis.com/v4/spreadsheets/spreadsheetId:batchUpdate

{
"requests": [
{
"addSheet": {
"properties": {
"hidden": true,
"title": "LOOKUP_SHEET"
}
}
}
]
}
  1. 在隐藏工作表的 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(INDIRECT(ADDRESS(MATCH("Search value",A:A,0),1)))。如果工作表中有空格,请将其括在单引号中。如果您要搜索数字,请确保不要将其括在引号中。

关于android - 谷歌表格 API : How to find a row by value and update it's content,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49161249/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com