aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--reader/reader.go31
-rw-r--r--reader/reader_test.go7
-rw-r--r--reader/testdata/test_template.xlsxbin8088 -> 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
index 5d7f0ce..5e2ea97 100644
--- a/reader/testdata/test_template.xlsx
+++ b/reader/testdata/test_template.xlsx
Binary files differ