将来自多个单元的数据组合到一个JSON对象中

时间:2016-02-29 21:50:14

标签: json excel go xlsx

我正在尝试将来自excel电子表格的多个单元格的数据组合成一个JSON编码的字符串。我无法弄清楚如何这样做,下面的代码是为每个单元格创建一个新的JSON对象。如何区分单元格以组合成相同的JSON字符串?

package main

import (
    "fmt"
    "github.com/tealeg/xlsx"
    "encoding/json"

)

func main() {
    excelFileName := "/Users/isaacmelton/Desktop/Test_Data.xlsx"
    xlFile, err := xlsx.OpenFile(excelFileName)
    if err != nil {
        fmt.Printf("Cannot parse data")
    }
    for _, sheet := range xlFile.Sheets {
        for _, row := range sheet.Rows {

            fmt.Printf("\n")
            for x, cell := range row.Cells {
                if x == 3 || x == 5 {
                    data := map[string]string{"d_name": cell.String(), "name": cell.String()}
                    json_data, _ := json.Marshal(data)

                    fmt.Println(string(json_data))
                }
            }
        }
    }
}

运行上面的代码会产生以下结果:

{"foo":"cell1","bar":"cell1"}
{"foo":"cell2","bar":"cell2"}

我期待这样的事情:

{"foo":"cell1", "bar":"cell2"}

2 个答案:

答案 0 :(得分:0)

如果我正确理解您的请求,您只需要定义根元素,在其中添加单元格并封送此元素而不是单个单元格。

root := []map[string]string{}
for x, cell := range row.Cells {
    if x == 3 || x == 5 {
        root = append(root, map[string]string{"d_name": cell.String(), "name": cell.String()})
    }
}
json_data, _ := json.Marshal(root)
fmt.Println(string(json_data))

http://play.golang.org/p/SHnShHvW_0

答案 1 :(得分:0)

您可以使用

a, err := row.Cells[3].String()
b, err := row.Cells[5].String()

喜欢这个工作代码:

package main

import (
    "encoding/json"
    "fmt"

    "github.com/tealeg/xlsx"
)

func main() {
    xlFile, err := xlsx.OpenFile(`Test_Data.xlsx`)
    if err != nil {
        panic(err)
    }
    for _, sheet := range xlFile.Sheets {
        for _, row := range sheet.Rows {
            //for x, cell := range row.Cells {
            //if x == 3 || x == 5 {
            a, err := row.Cells[3].String()
            if err != nil {
                panic(err)
            }
            b, err := row.Cells[5].String()
            if err != nil {
                panic(err)
            }
            data := map[string]string{"d_name": a, "name": b}
            json_data, err := json.Marshal(data)
            if err != nil {
                panic(err)
            }
            fmt.Println(string(json_data))
            //}
            //}
        }
    }
}

输出:

{"d_name":"1000","name":"a"}
{"d_name":"2000","name":"b"}
{"d_name":"3000","name":"c"}
{"d_name":"4000","name":"d"}
{"d_name":"5000","name":"e"}

输入文件内容:

1   10  100 1000    10000   a
2   20  200 2000    20000   b
3   30  300 3000    30000   c
4   40  400 4000    40000   d
5   50  500 5000    50000   e