-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathclient_reader.go
40 lines (34 loc) · 998 Bytes
/
client_reader.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
package herschel
// Read returns a slice of cell values in sheet.
func (client *Client) Read(spreadsheetID string, sheetTitle string) ([][]interface{}, error) {
resp, err := client.service.Spreadsheets.Values.Get(spreadsheetID, sheetTitle).Do()
if err != nil {
return nil, err
}
return resp.Values, nil
}
// ReadTable returns a table with values read from the spreadsheet set.
func (client *Client) ReadTable(spreadsheetID string, sheetTitle string) (*Table, error) {
values, err := client.Read(spreadsheetID, sheetTitle)
if err != nil {
return nil, err
}
maxCols := 0
for _, row := range values {
cols := len(row)
if cols > maxCols {
maxCols = cols
}
}
t := NewTable(len(values), maxCols)
for i, row := range values {
for j, col := range row {
t.PutValue(i, j, col)
}
}
return t, nil
}
// SheetTitles returns a slice of sheet titles.
func (client Client) SheetTitles(spreadsheetID string) ([]string, error) {
return getSheetTitles(client, spreadsheetID)
}