登录
首页 >  Golang >  Go问答

在 Go 语言中向 Google 表格添加数据的方法

来源:stackoverflow

时间:2024-02-19 18:36:26 335浏览 收藏

推广推荐
免费电影APP ➜
支持 PC / 移动端,安全直达

有志者,事竟成!如果你在学习Golang,那么本文《在 Go 语言中向 Google 表格添加数据的方法》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

问题内容

我正在尝试将数据插入或更新到 google 电子表格中。我正在使用 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"

当我尝试通过动态工作表名称保存时。 2.

error while updating records error: googleapi: error 400: unable to parse range: 655963475, badrequest"}

尝试使用sheetid时

如何使用 golang 中的工作表名称、工作表 id 和电子表格 id 将值插入或更新到 googlsheet 中。

这是我的错误情况 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
}

这是我的错误情况 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 的值附加到电子表格中。
    • 您希望在这种情况下使用工作表 id。
  • 您已经能够使用 sheets api 获取 google 电子表格中的值并将其写入其中。

既然如此,下面的修改如何?

遗憾的是,工作表 id 不能直接用于 srv.spreadsheets.values.append()。我认为这就是你的问题的原因。因此,在这种情况下,首先需要将sheet id转换为sheet名称。

修改后的脚本:

来自:

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
}

致:

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 将转换为工作表名称。并且,该值会附加到工作表中。

注意:

  • 如果可以直接使用sheet名称,脚本就变成如下。

    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 语言中向 Google 表格添加数据的方法》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>