summaryrefslogtreecommitdiff
path: root/excelize.go
diff options
context:
space:
mode:
Diffstat (limited to 'excelize.go')
-rw-r--r--excelize.go65
1 files changed, 57 insertions, 8 deletions
diff --git a/excelize.go b/excelize.go
index d37860f..15710db 100644
--- a/excelize.go
+++ b/excelize.go
@@ -11,21 +11,28 @@ import (
// File define a populated xlsx.File struct.
type File struct {
- XLSX map[string]string
- Path string
+ XLSX map[string]string
+ Path string
+ SheetCount int
}
// OpenFile take the name of an XLSX file and returns a populated
// xlsx.File struct for it.
-func OpenFile(filename string) *File {
+func OpenFile(filename string) (*File, error) {
var f *zip.ReadCloser
+ var err error
file := make(map[string]string)
- f, _ = zip.OpenReader(filename)
- file, _ = ReadZip(f)
- return &File{
- XLSX: file,
- Path: filename,
+ sheetCount := 0
+ f, err = zip.OpenReader(filename)
+ if err != nil {
+ return &File{}, err
}
+ file, sheetCount, err = ReadZip(f)
+ return &File{
+ XLSX: file,
+ Path: filename,
+ SheetCount: sheetCount,
+ }, nil
}
// SetCellInt provide function to set int type value of a cell
@@ -176,6 +183,7 @@ func replaceWorkSheetsRelationshipsNameSpace(workbookMarshal string) string {
// <c r="G15" s="1" />
// </row>
//
+// Noteice: this method could be very slow for large spreadsheets (more than 3000 rows one sheet).
func checkRow(xlsx xlsxWorksheet) xlsxWorksheet {
buffer := bytes.Buffer{}
for k, v := range xlsx.SheetData.Row {
@@ -207,3 +215,44 @@ func checkRow(xlsx xlsxWorksheet) xlsxWorksheet {
}
return xlsx
}
+
+// UpdateLinkedValue fix linked values within a spreadsheet are not updating.
+// This function will be remove value tag when met a cell have a linked value.
+// Reference https://social.technet.microsoft.com/Forums/office/en-US/e16bae1f-6a2c-4325-8013-e989a3479066/excel-2010-linked-cells-not-updating?forum=excel
+//
+// Notice: after open XLSX file Excel will be update linked value and generate
+// new value and will prompt save file or not.
+//
+// For example:
+//
+// <row r="19" spans="2:2">
+// <c r="B19">
+// <f>SUM(Sheet2!D2,Sheet2!D11)</f>
+// <v>100</v>
+// </c>
+// </row>
+//
+// to
+//
+// <row r="19" spans="2:2">
+// <c r="B19">
+// <f>SUM(Sheet2!D2,Sheet2!D11)</f>
+// </c>
+// </row>
+func (f *File) UpdateLinkedValue() {
+ for i := 1; i <= f.SheetCount; i++ {
+ var xlsx xlsxWorksheet
+ name := `xl/worksheets/sheet` + strconv.Itoa(i) + `.xml`
+ xml.Unmarshal([]byte(f.readXML(name)), &xlsx)
+ for indexR, row := range xlsx.SheetData.Row {
+ for indexC, col := range row.C {
+ if col.F != nil && col.V != `` {
+ xlsx.SheetData.Row[indexR].C[indexC].V = ``
+ xlsx.SheetData.Row[indexR].C[indexC].T = ``
+ }
+ }
+ }
+ output, _ := xml.Marshal(xlsx)
+ f.saveFileList(name, replaceRelationshipsID(replaceWorkSheetsRelationshipsNameSpace(string(output))))
+ }
+}