You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

xlsx.go 1.1 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. // Copyright 2023 The casbin Authors. All Rights Reserved.
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package xlsx
  15. import (
  16. "github.com/casbin/casibase/util"
  17. "github.com/tealeg/xlsx"
  18. )
  19. func ReadXlsxFile(fileId string) [][]string {
  20. path := util.GetUploadXlsxPath(fileId)
  21. file, err := xlsx.OpenFile(path)
  22. if err != nil {
  23. panic(err)
  24. }
  25. res := [][]string{}
  26. for _, sheet := range file.Sheets {
  27. for _, row := range sheet.Rows {
  28. line := []string{}
  29. for _, cell := range row.Cells {
  30. text := cell.String()
  31. line = append(line, text)
  32. }
  33. res = append(res, line)
  34. }
  35. break
  36. }
  37. return res
  38. }