diff options
| author | xuri <xuri.me@gmail.com> | 2018-10-27 14:47:55 +0800 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-10-27 14:47:55 +0800 | 
| commit | 42c3541f6840d6e4c03455401ec00f5ce1130d54 (patch) | |
| tree | a1c79f66f736ce3fed98a46325b35e9d449ac0d8 | |
| parent | 90bdd3632f16244583525e580fa3edd42361db68 (diff) | |
| parent | e2e58a3a441a169ff8e9e5e65caf545a15026c37 (diff) | |
Merge pull request #278 from peng/search-sheet
New function: `SearchSheet()`, relate issue #277
| -rw-r--r-- | sheet.go | 51 | 
1 files changed, 51 insertions, 0 deletions
| @@ -14,6 +14,7 @@ import (  	"encoding/json"  	"encoding/xml"  	"errors" +	"fmt"  	"io/ioutil"  	"os"  	"path" @@ -660,6 +661,56 @@ func (f *File) GetSheetVisible(name string) bool {  	return visible  } +// SearchSheet provides a function to get coordinates by given worksheet name +// and cell value. This function only supports exact match of strings and +// numbers, doesn't support the calculated result, formatted numbers and +// conditional lookup currently. If it is a merged cell, it will return the +// coordinates of the upper left corner of the merged area. For example, +// search the coordinates of the value of "100" on Sheet1: +// +//    xlsx.SearchSheet("Sheet1", "100") +// +func (f *File) SearchSheet(sheet, value string) []string { +	xlsx := f.workSheetReader(sheet) +	result := []string{} +	name, ok := f.sheetMap[trimSheetName(sheet)] +	if !ok { +		return result +	} +	if xlsx != nil { +		output, _ := xml.Marshal(f.Sheet[name]) +		f.saveFileList(name, replaceWorkSheetsRelationshipsNameSpaceBytes(output)) +	} +	xml.NewDecoder(bytes.NewReader(f.readXML(name))) +	d := f.sharedStringsReader() +	var inElement string +	var r xlsxRow +	decoder := xml.NewDecoder(bytes.NewReader(f.readXML(name))) +	for { +		token, _ := decoder.Token() +		if token == nil { +			break +		} +		switch startElement := token.(type) { +		case xml.StartElement: +			inElement = startElement.Name.Local +			if inElement == "row" { +				r = xlsxRow{} +				_ = decoder.DecodeElement(&r, &startElement) +				for _, colCell := range r.C { +					val, _ := colCell.getValueFrom(f, d) +					if val != value { +						continue +					} +					result = append(result, fmt.Sprintf("%s%d", strings.Map(letterOnlyMapF, colCell.R), r.R)) +				} +			} +		default: +		} +	} +	return result +} +  // trimSheetName provides a function to trim invaild characters by given worksheet  // name.  func trimSheetName(name string) string { | 
