aboutsummaryrefslogtreecommitdiffstats
path: root/pkg/datamaps/writer.go
diff options
context:
space:
mode:
Diffstat (limited to 'pkg/datamaps/writer.go')
-rw-r--r--pkg/datamaps/writer.go47
1 files changed, 37 insertions, 10 deletions
diff --git a/pkg/datamaps/writer.go b/pkg/datamaps/writer.go
index 54ea789..e1cb713 100644
--- a/pkg/datamaps/writer.go
+++ b/pkg/datamaps/writer.go
@@ -38,11 +38,6 @@ func ExportMaster(opts *Options) error {
wb := xlsx.NewFile()
sh, err := wb.AddSheet("Master Data")
- testRow, err := sh.Row(1)
- if err != nil {
- log.Fatal(err)
- }
-
// SQLITE CODE
db, err := sql.Open("sqlite3", opts.DBPath)
@@ -101,7 +96,7 @@ func ExportMaster(opts *Options) error {
INNER JOIN return on return_data.ret_id=return.id)
WHERE datamap.name=? AND return.name=? AND datamap_line.key=?;`
- var values = make([]string, rowCount+1)
+ var values = make(map[string][]string)
for _, k := range datamapKeys {
masterData, err := db.Query(getDataSQL, opts.DMName, opts.ReturnName, k)
if err != nil {
@@ -114,15 +109,23 @@ func ExportMaster(opts *Options) error {
if err := masterData.Scan(&key, &value, &filename); err != nil {
return err
}
- values = append(values, value)
+ values = appendValueMap(key, value, values)
}
}
}
- if sl := testRow.WriteSlice(values, -1); sl == -1 {
- log.Printf("not a slice type")
+ var masterRow int64
+ for masterRow = 1; masterRow <= datamapKeysNumber; masterRow++ {
+ r, err := sh.Row(int(masterRow))
+ if err != nil {
+ log.Fatal(err)
+ }
+ dmlKey := datamapKeys[masterRow-1]
+ if sl := r.WriteSlice(values[dmlKey], -1); sl == -1 {
+ log.Printf("not a slice type")
+ }
+ log.Printf("writing slice to row\n")
}
- log.Printf("writing slice to row\n")
log.Printf("saving master at %s", opts.MasterOutPutPath)
if err := wb.Save(filepath.Join(opts.MasterOutPutPath, "master.xlsx")); err != nil {
@@ -131,3 +134,27 @@ func ExportMaster(opts *Options) error {
sh.Close()
return nil
}
+
+func appendValueMap(k, v string, values map[string][]string) map[string][]string {
+
+ var keyIn bool
+ for kv, _ := range values {
+ if kv == k {
+ keyIn = true
+ break
+ }
+ }
+
+ if keyIn {
+ slice, ok := values[k]
+ if !ok {
+ log.Fatalf("%s is not a key in this map", k)
+ }
+ slice = append(slice, v)
+ values[k] = slice
+ return values
+ } else {
+ values[k] = []string{v}
+ return values
+ }
+}