diff options
Diffstat (limited to '')
-rw-r--r-- | reader/reader.go | 41 | ||||
-rw-r--r-- | reader/reader_test.go | 10 |
2 files changed, 44 insertions, 7 deletions
diff --git a/reader/reader.go b/reader/reader.go index 5357672..be9b5bc 100644 --- a/reader/reader.go +++ b/reader/reader.go @@ -116,6 +116,47 @@ func cols(n int) []string { return out } +// cellrefVal is a map of the cellref to the cell data +// as provided by the xlsx package +type cellrefVal map[string]ExtractedCell + +func ReadXLSToMap(dm string, tm string) map[string][]cellrefVal { + var out map[string][]cellrefVal + + // open the files + excelData, err := xlsx.OpenFile(tm) + if err != nil { + fmt.Printf("Cannot open %v", excelData) + } + + dmlData, err := ReadDML(dm) + if err != nil { + fmt.Errorf("Cannot read datamap file %v", dm) + } + + // get the data + for _, sheet := range excelData.Sheets { + sheetNames := getSheetNames(dmlData) + sheetData := make(map[string][]cellrefVal, len(sheetNames)) + var cellDataList []map[string]ExtractedCell + for rowLidx, row := range sheet.Rows { + for colLidx, cell := range row.Cells { + cellData := make(map[string]ExtractedCell) + ex := ExtractedCell{ + cell: cell, + colL: colstream[colLidx], + rowLidx: rowLidx + 1, + value: cell.Value} + cellref := fmt.Sprintf("%s%d", ex.colL, ex.rowLidx) + cellData[cellref] = ex + cellDataList = append(cellDataList, cellData) + sheetData[sheet.Name] = append(sheetData[sheet.Name], cellData) + } + } + } + return out +} + //ReadXLSX reads an XLSX file func ReadXLSX(fn string) []ExtractedCell { var out []ExtractedCell diff --git a/reader/reader_test.go b/reader/reader_test.go index b3d40c1..63d9a3e 100644 --- a/reader/reader_test.go +++ b/reader/reader_test.go @@ -101,11 +101,7 @@ func TestGetSheetsFromDM(t *testing.T) { } } -func TestSheetDataInMap(t *testing.T) { - // want to see data from a file in this form: - // Struct: - // filename: test_template.xlsx - // data: map[sheetName]sheetData - // we want to test ^^^^^^^^^^^^^ - +func TestReadXLSXToMap(t *testing.T) { + d := ReadXLSToMap("testdata/datamap.csv", "testdata/test_template.xlsx") + _ = d } |