diff options
Diffstat (limited to '')
-rw-r--r-- | reader/reader.go | 31 | ||||
-rw-r--r-- | reader/reader_test.go | 7 | ||||
-rw-r--r-- | reader/testdata/test_template.xlsx | bin | 8088 -> 9039 bytes |
3 files changed, 37 insertions, 1 deletions
diff --git a/reader/reader.go b/reader/reader.go index e0c3f66..71870c5 100644 --- a/reader/reader.go +++ b/reader/reader.go @@ -22,6 +22,8 @@ type ( SheetData map[string]ExtractedCell // Data from the file. FileData map[string]SheetData + // Data from the file, filtered by a Datamap. + ExtractedData map[string]map[string]xlsx.Cell ) var colstream = cols(maxAlphabets) @@ -117,7 +119,7 @@ func cols(n int) []string { return out } -//ReadXLSToMap returns the file's data as a map, +//ReadXLSX returns the file's data as a map, // keyed on sheet name. All values are returned as strings. // Paths to a datamap and the spreadsheet file required. func ReadXLSX(dm string, ssheet string) FileData { @@ -158,3 +160,30 @@ func ReadXLSX(dm string, ssheet string) FileData { } return output } + +//Extract returns the file's data as a map, +// keyed on sheet name. All values are returned as strings. +// Paths to a datamap and the spreadsheet file required. +func Extract(dm string, ssheet string) ExtractedData { + data := ReadXLSX(dm, ssheet) + dmlData, err := ReadDML(dm) + if err != nil { + log.Fatal(err) + } + sheetNames := getSheetNames(dmlData) + output := make(ExtractedData, len(sheetNames)) + + for _, i := range dmlData { + sheet := i.Sheet + cellref := i.Cellref + if val, ok := data[sheet][cellref]; ok { + // TODO check what is happening here... + // ddg "golang assingment to entry in nil map" + // first SO entry, but I don't think I totally understand + inner := make(map[string]xlsx.Cell) + inner[cellref] = *val.Cell + output[sheet] = inner + } + } + return output +} diff --git a/reader/reader_test.go b/reader/reader_test.go index 36dd8f1..3096c1b 100644 --- a/reader/reader_test.go +++ b/reader/reader_test.go @@ -98,3 +98,10 @@ func TestReadXLSX(t *testing.T) { t.Errorf("Expected J22 in Another Sheet sheet to be 18 - instead it is %s", d["Another Sheet"]["J22"].Value) } } + +func TestExtract(t *testing.T) { + d := Extract("testdata/datamap.csv", "testdata/test_template.xlsx") + if d["Introduction"]["C9"].Value != "Test Department" { + t.Errorf("Expected C9 in Introduction sheet to be Test Department - instead it is %s", d["Introduction"]["C9"].Value) + } +} diff --git a/reader/testdata/test_template.xlsx b/reader/testdata/test_template.xlsx Binary files differindex 5d7f0ce..5e2ea97 100644 --- a/reader/testdata/test_template.xlsx +++ b/reader/testdata/test_template.xlsx |