diff options
| author | xuri <xuri.me@gmail.com> | 2018-12-19 23:32:12 +0800 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-12-19 23:32:12 +0800 | 
| commit | 3ca3156d453076d5423b15cb47bfc8f027ebe95d (patch) | |
| tree | 1b834d6351ffedc86b420e1e1d3b6f41a02d1bb9 | |
| parent | 90221bd98fab0ce85a177d955d79a964bb4b66b2 (diff) | |
| parent | 3012df08eb81756704a8e3f47fff59d0a6bf693b (diff) | |
Merge pull request #313 from sairoutine/feature/get_merge_cells
Add GetMergeCells
| -rw-r--r-- | excelize.go | 40 | ||||
| -rw-r--r-- | excelize_test.go | 53 | ||||
| -rw-r--r-- | test/MergeCell.xlsx | bin | 0 -> 8583 bytes | 
3 files changed, 93 insertions, 0 deletions
| diff --git a/excelize.go b/excelize.go index 309a8d8..4b4aa32 100644 --- a/excelize.go +++ b/excelize.go @@ -411,3 +411,43 @@ func (f *File) adjustAutoFilterHelper(xlsx *xlsxWorksheet, column, rowIndex, off  		}  	}  } + +// GetMergeCells provides a function to get all merged cells from a worksheet currently. +func (f *File) GetMergeCells(sheet string) []MergeCell { +	mergeCells := []MergeCell{} + +	xlsx := f.workSheetReader(sheet) +	if xlsx.MergeCells != nil { +		for i := 0; i < len(xlsx.MergeCells.Cells); i++ { +			ref := xlsx.MergeCells.Cells[i].Ref +			axis := strings.Split(ref, ":")[0] +			mergeCells = append(mergeCells, []string{ref, f.GetCellValue(sheet, axis)}) +		} +	} + +	return mergeCells +} + +// MergeCell define a merged cell data. +// It consists of the following structure. +// example: []string{"D4:E10", "cell value"} +type MergeCell []string + +// GetCellValue returns merged cell value. +func (m *MergeCell) GetCellValue() string { +	return (*m)[1] +} + +// GetStartAxis returns the merge start axis. +// example: "C2" +func (m *MergeCell) GetStartAxis() string { +	axis := strings.Split((*m)[0], ":") +	return axis[0] +} + +// GetEndAxis returns the merge end axis. +// example: "D4" +func (m *MergeCell) GetEndAxis() string { +	axis := strings.Split((*m)[0], ":") +	return axis[1] +} diff --git a/excelize_test.go b/excelize_test.go index 89d2e98..6eb3692 100644 --- a/excelize_test.go +++ b/excelize_test.go @@ -374,6 +374,59 @@ func TestMergeCell(t *testing.T) {  	}  } +func TestGetMergeCells(t *testing.T) { +	wants := []struct { +		value string +		start string +		end   string +	}{ +		{ +			value: "A1", +			start: "A1", +			end:   "B1", +		}, +		{ +			value: "A2", +			start: "A2", +			end:   "A3", +		}, +		{ +			value: "A4", +			start: "A4", +			end:   "B5", +		}, +		{ +			value: "A7", +			start: "A7", +			end:   "C10", +		}, +	} + +	xlsx, err := OpenFile("./test/MergeCell.xlsx") +	if err != nil { +		t.Error(err) +	} + +	mergeCells := xlsx.GetMergeCells("Sheet1") +	if len(mergeCells) != len(wants) { +		t.Fatalf("Expected count of merge cells %d, but got %d\n", len(wants), len(mergeCells)) +	} + +	for i, m := range mergeCells { +		if wants[i].value != m.GetCellValue() { +			t.Fatalf("Expected merged cell value %s, but got %s\n", wants[i].value, m.GetCellValue()) +		} + +		if wants[i].start != m.GetStartAxis() { +			t.Fatalf("Expected merged cell value %s, but got %s\n", wants[i].start, m.GetStartAxis()) +		} + +		if wants[i].end != m.GetEndAxis() { +			t.Fatalf("Expected merged cell value %s, but got %s\n", wants[i].end, m.GetEndAxis()) +		} +	} +} +  func TestSetCellStyleAlignment(t *testing.T) {  	xlsx, err := OpenFile("./test/Book2.xlsx")  	if err != nil { diff --git a/test/MergeCell.xlsx b/test/MergeCell.xlsxBinary files differ new file mode 100644 index 0000000..d4dad18 --- /dev/null +++ b/test/MergeCell.xlsx | 
