我想从Google表格API中获取所有行。它使用type
返回数据
[][]interface{}
。
我的结构是
type Record struct {
Name string `json:"firstname"`
Mobile string `json:"mobile"`
}
我想将所有行放入结构[]Record
的切片中,其中每个字段都是excel工作表中的单元格。
请尝试以下代码:
package main
import (
"encoding/json"
"fmt"
"log"
)
func main() {
srv err := InitialiseSheets()
fmt.Println("")
if err != nil {
log.Fatalf("Unable to retrieve data from sheet: %v", err)
}
spreadsheetId := "1VoMAKHSnB6nptPnQqabMlKWraxWolYgPBxRo-thwmgk"
readRange := "A:B"
resp, err := srv.Spreadsheets.Values.Get(spreadsheetId, readRange).Do()
if err != nil {
log.Fatalf("Unable to retrieve data from sheet: %v", err)
}
var records []Record = make([]Record, len(resp.Values))
byt, err := resp.MarshalJSON()
var dat map[string]interface{}
if err = json.Unmarshal(byt, &dat); err != nil {
panic(err)
}
for key, value := range dat {
switch key {
case "values":
switch vv := value.(type) {
case []interface{}:
for i, u := range vv {
switch r := u.(type) {
case interface{}:
records[i].Name = r.([]interface{})[0].(string)
records[i].Mobile = r.([]interface{})[1].(string)
// [Daniel Webster 425255565]
fmt.Println("kk.([]interface{})", r.([]interface{}))
// [Daniel Webster]
fmt.Println("kk.([]interface{})[0]", r.([]interface{})[0])
}
}
}
}
}
}
我确定执行records[i].Mobile = r.([]interface{})[1].(string)
之类的方法不是正确的方法,也不确定我是怎么想到的。 Go中要做我想要达到的最佳方法是什么?
如果您想运行此代码,请先遵循以下步骤设置身份验证:https://developers.google.com/sheets/api/quickstart/go,然后您可以复制/粘贴我的代码。
答案 0 :(得分:0)
此修改如何?在这种情况下,值直接从resp.Values
到records
。
func main() {
srv err := InitialiseSheets()
fmt.Println("")
if err != nil {
log.Fatalf("Unable to retrieve data from sheet: %v", err)
}
spreadsheetId := "1VoMAKHSnB6nptPnQqabMlKWraxWolYgPBxRo-thwmgk"
readRange := "A:B"
resp, err := srv.Spreadsheets.Values.Get(spreadsheetId, readRange).Do()
if err != nil {
log.Fatalf("Unable to retrieve data from sheet: %v", err)
}
var records []Record = make([]Record, len(resp.Values))
// Below script was modified.
for i, row := range resp.Values {
records[i].Name = row[0].(string)
records[i].Mobile = row[1].(string)
}
// do something
}