Merge pull request #275 from Zheaoli/master
Add Support for WriteTo Buffer
This commit is contained in:
commit
d8a34af384
|
@ -135,6 +135,10 @@ func TestOpenFile(t *testing.T) {
|
|||
if err != nil {
|
||||
t.Log(err)
|
||||
}
|
||||
_, err = xlsx.WriteToBuffer()
|
||||
if err != nil {
|
||||
t.Error(err)
|
||||
}
|
||||
}
|
||||
|
||||
func TestAddPicture(t *testing.T) {
|
||||
|
|
20
file.go
20
file.go
|
@ -76,6 +76,15 @@ func (f *File) Write(w io.Writer) error {
|
|||
|
||||
// WriteTo implements io.WriterTo to write the file.
|
||||
func (f *File) WriteTo(w io.Writer) (int64, error) {
|
||||
buf, err := f.WriteToBuffer()
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
return buf.WriteTo(w)
|
||||
}
|
||||
|
||||
// WriteToBuffer provides a function to get bytes.Buffer from the saved file.
|
||||
func (f *File) WriteToBuffer() (*bytes.Buffer, error) {
|
||||
buf := new(bytes.Buffer)
|
||||
zw := zip.NewWriter(buf)
|
||||
f.contentTypesWriter()
|
||||
|
@ -86,17 +95,12 @@ func (f *File) WriteTo(w io.Writer) (int64, error) {
|
|||
for path, content := range f.XLSX {
|
||||
fi, err := zw.Create(path)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
return buf, err
|
||||
}
|
||||
_, err = fi.Write(content)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
return buf, err
|
||||
}
|
||||
}
|
||||
err := zw.Close()
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
|
||||
return buf.WriteTo(w)
|
||||
return buf, zw.Close()
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue