rows.go 3.5 KB

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