rows.go 3.6 KB

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