2020-01-26 00:39:13 -05:00
|
|
|
package d2common
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
// DataDictionary represents a data file (Excel)
|
|
|
|
type DataDictionary struct {
|
|
|
|
FieldNameLookup map[string]int
|
|
|
|
Data [][]string
|
|
|
|
}
|
|
|
|
|
|
|
|
func LoadDataDictionary(text string) *DataDictionary {
|
|
|
|
result := &DataDictionary{}
|
|
|
|
lines := strings.Split(text, "\r\n")
|
|
|
|
fileNames := strings.Split(lines[0], "\t")
|
|
|
|
result.FieldNameLookup = make(map[string]int)
|
|
|
|
for i, fieldName := range fileNames {
|
|
|
|
result.FieldNameLookup[fieldName] = i
|
|
|
|
}
|
2020-05-08 12:33:37 -04:00
|
|
|
result.Data = make([][]string, len(lines)-2)
|
2020-01-26 00:39:13 -05:00
|
|
|
for i, line := range lines[1:] {
|
|
|
|
if len(strings.TrimSpace(line)) == 0 {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
values := strings.Split(line, "\t")
|
|
|
|
if len(values) != len(result.FieldNameLookup) {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
result.Data[i] = values
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|
|
|
|
|
|
|
|
func (v *DataDictionary) GetString(fieldName string, index int) string {
|
|
|
|
return v.Data[index][v.FieldNameLookup[fieldName]]
|
|
|
|
}
|
|
|
|
|
|
|
|
func (v *DataDictionary) GetNumber(fieldName string, index int) int {
|
2020-05-08 12:33:37 -04:00
|
|
|
str := v.GetString(fieldName, index)
|
|
|
|
str = EmptyToZero(AsterToEmpty(str))
|
|
|
|
result, err := strconv.Atoi(str)
|
2020-01-26 00:39:13 -05:00
|
|
|
if err != nil {
|
|
|
|
log.Panic(err)
|
|
|
|
}
|
|
|
|
return result
|
|
|
|
}
|