-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild_xlsx_template.go
91 lines (80 loc) · 2.11 KB
/
build_xlsx_template.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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
package main
import (
"io"
"log"
"text/template"
)
func GenerateTemplate(outputFile io.Writer, templateData TemplateData) {
outputTemplate := `package {{.PakageName}}
import (
"log"
"strconv"
"github.com/xuri/excelize/v2"
)
func init() {
f, err := excelize.OpenFile("xlsx/{{.FileName}}.xlsx")
if err != nil {
log.Println("xlsx/{{.FileName}}.xlsx异常: ", err)
return
}
defer f.Close()
{{range .StructInfos}}init{{.Name}}(f)
{{end}}
}
{{range .StructInfos}}
{{$cName := getCfgName $.FileName .Name}}
var {{$cName}} = make(map[{{with index .Fields 0}}{{.Type}}{{end}}]*{{.Name}})
func init{{.Name}}(f *excelize.File) {
rows, err := f.GetRows("{{.SheetName}}")
if err != nil {
log.Println("xlsx/{{$.FileName}}.xlsx获取sheet<{{.SheetName}}>异常: ", err)
return
}
for _, row := range rows[2:] {
data := &{{.Name}}{}
{{range .Fields}}
{{if eq .Type "string"}}data.{{.Name}} = row[{{.Index}}]
{{else if eq .Type "int"}}
v{{.Index}}, err := strconv.Atoi(row[{{.Index}}])
if err != nil {
log.Println("类型转换错误: ", err)
return
}
data.{{.Name}} = v{{.Index}}{{else if eq .Type "bool"}}
v{{.Index}}, err := strconv.ParseBool(row[{{.Index}}])
if err != nil {
log.Println("类型转换错误: ", err)
return
}
data.{{.Name}} = v{{.Index}}{{end}}{{end}}
{{with index .Fields 0}}{{$cName}}[data.{{.Name}}] = data{{end}}
}
}
type {{.Name}} struct {
{{range .Fields}}{{.Name}} {{.Type}}
{{end}}
}
func (c *{{.Name}}) GetData(keys ...{{with index .Fields 0}}{{.Type}}{{end}}) []*{{.Name}} {
datas := make([]*{{.Name}}, 0)
for _, key := range keys {
datas = append(datas, {{$cName}}[key])
}
return datas
}
{{end}}
`
tmpl, err := template.New("output").Funcs(template.FuncMap{
"getCfgName": func(fname string, sname string) string {
return fname + sname + "Cfgs"
},
}).Parse(outputTemplate)
if err != nil {
log.Println("模板解析失败: ", err)
return
}
err = tmpl.Execute(outputFile, templateData)
if err != nil {
log.Println("模板导出失败: ", err)
return
}
}