我正在try 在谷歌Electron 表格中插入或更新数据.我使用的是golang模块"google.golang.org/api/option"和"google.golang.org/api/sheets/v4"下的包

我得到的错误如下:-1.

 got HTTP response code 404 with body: <!DOCTYPE html>\n<html lang=en>\n  <meta charset=utf-8>\n  <meta name=viewport content=\"initial-scale=1, minimum-scale=1, width=device-width\">\n  <title>Error 404 (Not Found)!!1</title>\n  <style>\n    *{margin:0;padding:0}html,code{font:15px/22px arial,sans-serif}html{background:#fff;color:#222;padding:15px}body{margin:7% auto 0;max-width:390px;min-height:180px;padding:30px 0 15px}* > body{background:url(//www.google.com/images/errors/robot.png) 100% 5px no-repeat;padding-right:205px}p{margin:11px 0 22px;overflow:hidden}ins{color:#777;text-decoration:none}a img{border:0}@media screen and (max-width:772px){body{background:none;margin-top:0;max-width:none;padding-right:0}}#logo{background:url(//www.google.com/images/branding/googlelogo/1x/googlelogo_color_150x54dp.png) no-repeat;margin-left:-5px}@media only screen and (min-resolution:192dpi){#logo{background:url(//www.google.com/images/branding/googlelogo/2x/googlelogo_color_150x54dp.png) no-repeat 0% 0%/100% 100%;-moz-border-image:url(//www.google.com/images/branding/googlelogo/2x/googlelogo_color_150x54dp.png) 0}}@media only screen and (-webkit-min-device-pixel-ratio:2){#logo{background:url(//www.google.com/images/branding/googlelogo/2x/googlelogo_color_150x54dp.png) no-repeat;-webkit-background-size:100% 100%}}#logo{display:inline-block;height:54px;width:150px}\n  </style>\n  <a href=//www.google.com/><span id=logo aria-label=Google></span></a>\n  <p><b>404.</b> <ins>That’s an error.</ins>\n  <p>The requested URL <code>/v4/spreadsheets/11dlAKQVB2Hb88fPtg7B9sdPkjmhbNxY8L6H-F1ZY5FI/values/:append?alt=json&amp;insertDataOption=INSERT_ROWS&amp;prettyPrint=false&amp;valueInputOption=USER_ENTERED</code> was not found on this server.  <ins>That’s all we know.</ins>\n"

当我试图通过动态sheetname保存时.

Error while updating records error: googleapi: Error 400: Unable to parse range: 655963475, badRequest"}

在try 使用sheetId时

How can I insert or update values into googlsheet using sheetname, sheetid and spreadsheetid in golang.

以下是我的错误 case 2代码:-

func SaveRecords(reqId string, credentials, tokenConfig []byte, spreadsheetId, sheetname string, records [][]interface{}) error {
    ctx := context.Background()

    config, err := google.ConfigFromJSON(credentials, "https://www.googleapis.com/auth/spreadsheets")
    if err != nil {
        return err
    }
    token := oauth2.Token{}
    json.Unmarshal(tokenConfig, &token)

    client := config.Client(ctx, &token)
    srv, err := sheets.NewService(ctx, option.WithHTTPClient(client))
    if err != nil {
        log.Print(err)
return err
    }

    valueInputOption := "USER_ENTERED"
    insertDataOption := "INSERT_ROWS"
    rb := &sheets.ValueRange{
        Values: records,
    }
    response, err := srv.Spreadsheets.Values.Append(spreadsheetId, sheetname, rb).ValueInputOption(valueInputOption).InsertDataOption(insertDataOption).Context(ctx).Do()
    if err != nil || response.HTTPStatusCode != 200 {
        
        return err
    }
    return nil
}

以下是我的错误 case 1代码:-

func SaveRecords(reqId string, credentials, tokenConfig []byte, spreadsheetId, sheetname string,sheetid string, records [][]interface{}) error {
    ctx := context.Background()

    config, err := google.ConfigFromJSON(credentials, "https://www.googleapis.com/auth/spreadsheets")
    if err != nil {
        return err
    }
    token := oauth2.Token{}
    json.Unmarshal(tokenConfig, &token)

    client := config.Client(ctx, &token)
    srv, err := sheets.NewService(ctx, option.WithHTTPClient(client))
    if err != nil {
        log.Print(err)
return err
    }

    valueInputOption := "USER_ENTERED"
    insertDataOption := "INSERT_ROWS"
    rb := &sheets.ValueRange{
        Values: records,
    }
    response, err := srv.Spreadsheets.Values.Append(spreadsheetId, sheetid, rb).ValueInputOption(valueInputOption).InsertDataOption(insertDataOption).Context(ctx).Do()
    if err != nil || response.HTTPStatusCode != 200 {
        
        return err
    }
    return nil
}

推荐答案

我相信你的目标如下.

  • 您希望使用golang的googleapis将值records附加到Electron 表格中.
  • 您已经能够使用Sheets API获取并将值输入谷歌Electron 表格.

在这种情况下,下面的修改如何?

不幸的是,不能直接使用sheet ID设置为srv.Spreadsheets.Values.Append().我认为这就是你问题的原因.因此,在本例中,首先需要将图纸ID转换为图纸名称.

修改脚本:

From:

valueInputOption := "USER_ENTERED"
insertDataOption := "INSERT_ROWS"
rb := &sheets.ValueRange{
    Values: records,
}
response, err := srv.Spreadsheets.Values.Append(spreadsheetId, sheetname, rb).ValueInputOption(valueInputOption).InsertDataOption(insertDataOption).Context(ctx).Do()
if err != nil || response.HTTPStatusCode != 200 {
    
    return err
}

To:

sheetid := 0 // Please set sheet ID.
spreadsheetId := "###" // Please set Spreadsheet ID
records := [][]interface{}{{"a1", "b1", "c1"}} // This is a sample value.

// 1. Convert sheet ID to sheet name.
response1, err := srv.Spreadsheets.Get(spreadsheetId).Fields("sheets(properties(sheetId,title))").Do()
if err != nil || response1.HTTPStatusCode != 200 {
    return err
}
sheetName := ""
for _, v := range response1.Sheets {
    prop := v.Properties
    sheetID := prop.SheetId
    if sheetID == int64(sheetid) {
        sheetName = prop.Title
        break
    }
}

// 2. Append value to the sheet.
valueInputOption := "USER_ENTERED"
insertDataOption := "INSERT_ROWS"
rb := &sheets.ValueRange{
    Values: records,
}
response2, err := srv.Spreadsheets.Values.Append(spreadsheetId, sheetName, rb).ValueInputOption(valueInputOption).InsertDataOption(insertDataOption).Context(ctx).Do()
if err != nil || response2.HTTPStatusCode != 200 {
    return err
}
  • 运行此脚本时,图纸ID将转换为图纸名称.然后,该值被附加到图纸上.

注:

  • 如果可以直接使用工作表名称,则脚本如下所示.

      sheetName := "Sheet1" // Please set sheet name.
      spreadsheetId := "###" // Please set Spreadsheet ID
      records := [][]interface{}{{"a1", "b1", "c1"}} // This is a sample value.
    
      valueInputOption := "USER_ENTERED"
      insertDataOption := "INSERT_ROWS"
      rb := &sheets.ValueRange{
          Values: records,
      }
      response2, err := srv.Spreadsheets.Values.Append(spreadsheetId, sheetName, rb).ValueInputOption(valueInputOption).InsertDataOption(insertDataOption).Context(ctx).Do()
      if err != nil || response2.HTTPStatusCode != 200 {
          return err
      }
    

参考资料:

Go相关问答推荐

为什么使用append时Go切片的初始容量会随着int32和int64类型的不同而变化?

追加一个字节数组的分配比2个字节数组的分配要少得多

从Kafka到Clickhouse的实时消费数据

允许在 struct 中使用复合作为函数参数

由docker中的nginx提供的样式和图像在页面上不起作用

如何使用gopher-lua定义一个Lua函数,该函数有一个预定义的表作为param,Lua脚本可以在其中访问该函数中的表?

通过代理从golang连接到ftp

Redis:尽管数据存在,但 rdb.Pipelined 中出现redis:nil错误

Go Gin:验证 base64

从 ApiGateway 中的 lambda Go 返回 Json

如何在 Go msgraph-sdk-go 中转发消息并包括抄送和/或密送收件人?

设置 graphql 的最大文件上传大小(golang)

转换朴素递归硬币问题时的记忆错误

如何模仿联合类型

Golang Gin 绑定请求正文 XML 到 Slice

io.Pipe 使用困难

如何在Go中替换符号并使下一个字母大写

使用 xml.Name 将 xml 解组为 [] struct

无法识别同步错误.使用一次

为什么在 goroutine 中声明时,benbjohnson/clock 模拟计时器不执行?