rows.go 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  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 r xlsxRow
  27. var row []string
  28. tr, tc := f.getTotalRowsCols(sheet)
  29. for i := 0; i < tr; i++ {
  30. row = []string{}
  31. for j := 0; j <= tc; j++ {
  32. row = append(row, "")
  33. }
  34. rows = append(rows, row)
  35. }
  36. decoder = xml.NewDecoder(strings.NewReader(f.readXML(name)))
  37. for {
  38. token, _ := decoder.Token()
  39. if token == nil {
  40. break
  41. }
  42. switch startElement := token.(type) {
  43. case xml.StartElement:
  44. inElement = startElement.Name.Local
  45. if inElement == "row" {
  46. r = xlsxRow{}
  47. decoder.DecodeElement(&r, &startElement)
  48. cr := r.R - 1
  49. for _, colCell := range r.C {
  50. c := titleToNumber(strings.Map(letterOnlyMapF, colCell.R))
  51. val, _ := colCell.getValueFrom(f, d)
  52. rows[cr][c] = val
  53. }
  54. }
  55. default:
  56. }
  57. }
  58. return rows
  59. }
  60. // getTotalRowsCols provides a function to get total columns and rows in a
  61. // sheet.
  62. func (f *File) getTotalRowsCols(sheet string) (int, int) {
  63. name := "xl/worksheets/" + strings.ToLower(sheet) + ".xml"
  64. decoder := xml.NewDecoder(strings.NewReader(f.readXML(name)))
  65. var inElement string
  66. var r xlsxRow
  67. var tr, tc int
  68. for {
  69. token, _ := decoder.Token()
  70. if token == nil {
  71. break
  72. }
  73. switch startElement := token.(type) {
  74. case xml.StartElement:
  75. inElement = startElement.Name.Local
  76. if inElement == "row" {
  77. r = xlsxRow{}
  78. decoder.DecodeElement(&r, &startElement)
  79. tr = r.R
  80. for _, colCell := range r.C {
  81. col := titleToNumber(strings.Map(letterOnlyMapF, colCell.R))
  82. if col > tc {
  83. tc = col
  84. }
  85. }
  86. }
  87. default:
  88. }
  89. }
  90. return tr, tc
  91. }
  92. // SetRowHeight provides a function to set the height of a single row.
  93. // For example:
  94. //
  95. // xlsx := excelize.CreateFile()
  96. // xlsx.SetRowHeight("Sheet1", 0, 50)
  97. // err := xlsx.Save()
  98. // if err != nil {
  99. // fmt.Println(err)
  100. // os.Exit(1)
  101. // }
  102. //
  103. func (f *File) SetRowHeight(sheet string, rowIndex int, height float64) {
  104. xlsx := xlsxWorksheet{}
  105. name := "xl/worksheets/" + strings.ToLower(sheet) + ".xml"
  106. xml.Unmarshal([]byte(f.readXML(name)), &xlsx)
  107. rows := rowIndex + 1
  108. cells := 0
  109. completeRow(&xlsx, rows, cells)
  110. xlsx.SheetData.Row[rowIndex].Ht = strconv.FormatFloat(height, 'f', -1, 64)
  111. xlsx.SheetData.Row[rowIndex].CustomHeight = true
  112. output, _ := xml.Marshal(xlsx)
  113. f.saveFileList(name, replaceWorkSheetsRelationshipsNameSpace(string(output)))
  114. }
  115. // readXMLSST read xmlSST simple function.
  116. func readXMLSST(f *File) (*xlsxSST, error) {
  117. shardStrings := xlsxSST{}
  118. err := xml.Unmarshal([]byte(f.readXML("xl/sharedStrings.xml")), &shardStrings)
  119. return &shardStrings, err
  120. }
  121. // getValueFrom return a value from a column/row cell, this function is inteded
  122. // to be used with for range on rows an argument with the xlsx opened file.
  123. func (xlsx *xlsxC) getValueFrom(f *File, d *xlsxSST) (string, error) {
  124. switch xlsx.T {
  125. case "s":
  126. xlsxSI := 0
  127. xlsxSI, _ = strconv.Atoi(xlsx.V)
  128. if len(d.SI[xlsxSI].R) > 0 {
  129. value := ""
  130. for _, v := range d.SI[xlsxSI].R {
  131. value += v.T
  132. }
  133. return value, nil
  134. }
  135. return d.SI[xlsxSI].T, nil
  136. case "str":
  137. return xlsx.V, nil
  138. default:
  139. return xlsx.V, nil
  140. }
  141. }