gpt4 book ai didi

java - 一个请求创建工作表和更新数据

转载 作者:搜寻专家 更新时间:2023-10-31 19:32:08 25 4
gpt4 key购买 nike

我想通过一次 API 调用来实现 Google 表格 API 请求。

我设法实现了这段代码:

List<Request> requests = new ArrayList<>();

List<CellData> values = new ArrayList<>();

values.add(new CellData()
.setUserEnteredValue(new ExtendedValue()
.setStringValue("Hello World!")));

requests.add(new Request().setAddSheet(new AddSheetRequest()
.setProperties(new SheetProperties()
.setTitle("scstc")))
.setUpdateCells(new UpdateCellsRequest()
.setStart(new GridCoordinate()
.setSheetId(0)
.setRowIndex(0)
.setColumnIndex(0))
.setRows(Arrays.asList(
new RowData().setValues(values)))
.setFields("userEnteredValue,userEnteredFormat.backgroundColor"))
);

BatchUpdateSpreadsheetRequest body = new BatchUpdateSpreadsheetRequest().setRequests(requests);

BatchUpdateSpreadsheetResponse response = service.spreadsheets().batchUpdate(spreadsheetId, body).execute();

但是我得到错误:

400 Bad Request
{
"code" : 400,
"errors" : [ {
"domain" : "global",
"message" : "Invalid value at 'requests[0]' (oneof), oneof field 'kind' is already set. Cannot set 'updateCells'",
"reason" : "badRequest"
} ],
"message" : "Invalid value at 'requests[0]' (oneof), oneof field 'kind' is already set. Cannot set 'updateCells'",
"status" : "INVALID_ARGUMENT"
}
at com.google.sheet.impl.GoogleSheetBasicTest1_____1.hello(GoogleSheetBasicTest1_____1.java:133)

你知道我该如何解决这个问题吗?

最佳答案

每个 Request 对象都旨在在其中设置一个值。您正在设置两个值:

requests.add(new Request()
.setAddSheet(...)
.setUpdateCells(...));

您需要使用两个请求对象来代替上述操作:

requests.add(new Request().setAddSheet(...));
requests.add(new Request().setUpdateCells(...));

关于java - 一个请求创建工作表和更新数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41347280/

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