file.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. package excelize
  2. import (
  3. "archive/zip"
  4. "bytes"
  5. "fmt"
  6. "io"
  7. "os"
  8. )
  9. // NewFile provides function to create new file by default template. For
  10. // example:
  11. //
  12. // xlsx := NewFile()
  13. //
  14. func NewFile() *File {
  15. file := make(map[string]string)
  16. file["_rels/.rels"] = XMLHeader + templateRels
  17. file["docProps/app.xml"] = XMLHeader + templateDocpropsApp
  18. file["docProps/core.xml"] = XMLHeader + templateDocpropsCore
  19. file["xl/_rels/workbook.xml.rels"] = XMLHeader + templateWorkbookRels
  20. file["xl/theme/theme1.xml"] = XMLHeader + templateTheme
  21. file["xl/worksheets/sheet1.xml"] = XMLHeader + templateSheet
  22. file["xl/styles.xml"] = XMLHeader + templateStyles
  23. file["xl/workbook.xml"] = XMLHeader + templateWorkbook
  24. file["[Content_Types].xml"] = XMLHeader + templateContentTypes
  25. return &File{
  26. Sheet: make(map[string]*xlsxWorksheet),
  27. XLSX: file,
  28. }
  29. }
  30. // Save provides function to override the xlsx file with origin path.
  31. func (f *File) Save() error {
  32. if f.Path == "" {
  33. return fmt.Errorf("No path defined for file, consider File.WriteTo or File.Write")
  34. }
  35. return f.SaveAs(f.Path)
  36. }
  37. // SaveAs provides function to create or update to an xlsx file at the provided
  38. // path.
  39. func (f *File) SaveAs(name string) error {
  40. file, err := os.OpenFile(name, os.O_WRONLY|os.O_TRUNC|os.O_CREATE, 0666)
  41. if err != nil {
  42. return err
  43. }
  44. defer file.Close()
  45. return f.Write(file)
  46. }
  47. // Write provides function to write to an io.Writer.
  48. func (f *File) Write(w io.Writer) error {
  49. buf := new(bytes.Buffer)
  50. zw := zip.NewWriter(buf)
  51. f.contentTypesWriter()
  52. f.workbookWriter()
  53. f.workbookRelsWriter()
  54. f.worksheetWriter()
  55. f.styleSheetWriter()
  56. for path, content := range f.XLSX {
  57. fi, err := zw.Create(path)
  58. if err != nil {
  59. return err
  60. }
  61. _, err = fi.Write([]byte(content))
  62. if err != nil {
  63. return err
  64. }
  65. }
  66. err := zw.Close()
  67. if err != nil {
  68. return err
  69. }
  70. if _, err := buf.WriteTo(w); err != nil {
  71. return err
  72. }
  73. return nil
  74. }