rows.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. package excelize
  2. import (
  3. "encoding/xml"
  4. "strconv"
  5. "strings"
  6. )
  7. // GetRows return all the rows in a sheet, for example:
  8. //
  9. // rows := xlsx.GetRows("Sheet2")
  10. // for _, row := range rows {
  11. // for _, colCell := range row {
  12. // fmt.Print(colCell, "\t")
  13. // }
  14. // fmt.Println()
  15. // }
  16. //
  17. func (f *File) GetRows(sheet string) [][]string {
  18. rows := [][]string{}
  19. name := "xl/worksheets/" + strings.ToLower(sheet) + ".xml"
  20. decoder := xml.NewDecoder(strings.NewReader(f.readXML(name)))
  21. d, err := readXMLSST(f)
  22. if err != nil {
  23. return rows
  24. }
  25. var inElement string
  26. var row []string
  27. for {
  28. token, _ := decoder.Token()
  29. if token == nil {
  30. break
  31. }
  32. switch startElement := token.(type) {
  33. case xml.StartElement:
  34. inElement = startElement.Name.Local
  35. if inElement == "row" {
  36. var r xlsxRow
  37. decoder.DecodeElement(&r, &startElement)
  38. for _, colCell := range r.C {
  39. val, _ := colCell.getValueFrom(f, d)
  40. row = append(row, val)
  41. }
  42. rows = append(rows, row)
  43. row = row[:0]
  44. }
  45. default:
  46. }
  47. }
  48. return rows
  49. }
  50. // SetRowHeight provides a function to set the height of a single row.
  51. // For example:
  52. //
  53. // xlsx := excelize.CreateFile()
  54. // xlsx.SetRowHeight("Sheet1", 0, 50)
  55. // err := xlsx.Save()
  56. // if err != nil {
  57. // fmt.Println(err)
  58. // os.Exit(1)
  59. // }
  60. //
  61. func (f *File) SetRowHeight(sheet string, rowIndex int, height float64) {
  62. xlsx := xlsxWorksheet{}
  63. name := "xl/worksheets/" + strings.ToLower(sheet) + ".xml"
  64. xml.Unmarshal([]byte(f.readXML(name)), &xlsx)
  65. rows := rowIndex + 1
  66. cells := 0
  67. xlsx = completeRow(xlsx, rows, cells)
  68. xlsx.SheetData.Row[rowIndex].Ht = strconv.FormatFloat(height, 'f', -1, 64)
  69. xlsx.SheetData.Row[rowIndex].CustomHeight = true
  70. output, _ := xml.Marshal(xlsx)
  71. f.saveFileList(name, replaceWorkSheetsRelationshipsNameSpace(string(output)))
  72. }
  73. // readXMLSST read xmlSST simple function.
  74. func readXMLSST(f *File) (*xlsxSST, error) {
  75. shardStrings := xlsxSST{}
  76. err := xml.Unmarshal([]byte(f.readXML("xl/sharedStrings.xml")), &shardStrings)
  77. return &shardStrings, err
  78. }
  79. // getValueFrom return a value from a column/row cell, this function is inteded
  80. // to be used with for range on rows an argument with the xlsx opened file.
  81. func (xlsx *xlsxC) getValueFrom(f *File, d *xlsxSST) (string, error) {
  82. switch xlsx.T {
  83. case "s":
  84. xlsxSI := 0
  85. xlsxSI, _ = strconv.Atoi(xlsx.V)
  86. if len(d.SI[xlsxSI].R) > 0 {
  87. value := ""
  88. for _, v := range d.SI[xlsxSI].R {
  89. value += v.T
  90. }
  91. return value, nil
  92. }
  93. return d.SI[xlsxSI].T, nil
  94. case "str":
  95. return xlsx.V, nil
  96. default:
  97. return xlsx.V, nil
  98. }
  99. }