@ -392,19 +392,18 @@ func (f *File) GetSheetIndex(sheet string) int {
// GetSheetMap provides a function to get worksheets, chart sheets, dialog
// GetSheetMap provides a function to get worksheets, chart sheets, dialog
// sheets ID and name map of the workbook. For example:
// sheets ID and name map of the workbook. For example:
//
//
// f, err := excelize.OpenFile("Book1.xlsx")
// f, err := excelize.OpenFile("Book1.xlsx")
// if err != nil {
// if err != nil {
// return
// return
// }
// }
// defer func() {
// defer func() {
// if err := f.Close(); err != nil {
// if err := f.Close(); err != nil {
// fmt.Println(err)
// fmt.Println(err)
// }
// }
// }()
// }()
// for index, name := range f.GetSheetMap() {
// for index, name := range f.GetSheetMap() {
// fmt.Println(index, name)
// fmt.Println(index, name)
// }
// }
//
func ( f * File ) GetSheetMap ( ) map [ int ] string {
func ( f * File ) GetSheetMap ( ) map [ int ] string {
wb := f . workbookReader ( )
wb := f . workbookReader ( )
sheetMap := map [ int ] string { }
sheetMap := map [ int ] string { }
@ -588,11 +587,10 @@ func (f *File) deleteSheetFromContentTypes(target string) {
// target worksheet index. Note that currently doesn't support duplicate
// target worksheet index. Note that currently doesn't support duplicate
// workbooks that contain tables, charts or pictures. For Example:
// workbooks that contain tables, charts or pictures. For Example:
//
//
// // Sheet1 already exists...
// // Sheet1 already exists...
// index := f.NewSheet("Sheet2")
// index := f.NewSheet("Sheet2")
// err := f.CopySheet(1, index)
// err := f.CopySheet(1, index)
// return err
// return err
//
func ( f * File ) CopySheet ( from , to int ) error {
func ( f * File ) CopySheet ( from , to int ) error {
if from < 0 || to < 0 || from == to || f . GetSheetName ( from ) == "" || f . GetSheetName ( to ) == "" {
if from < 0 || to < 0 || from == to || f . GetSheetName ( from ) == "" || f . GetSheetName ( to ) == "" {
return ErrSheetIdx
return ErrSheetIdx
@ -634,14 +632,13 @@ func (f *File) copySheet(from, to int) error {
// worksheet has been activated, this setting will be invalidated. Sheet state
// worksheet has been activated, this setting will be invalidated. Sheet state
// values as defined by https://docs.microsoft.com/en-us/dotnet/api/documentformat.openxml.spreadsheet.sheetstatevalues
// values as defined by https://docs.microsoft.com/en-us/dotnet/api/documentformat.openxml.spreadsheet.sheetstatevalues
//
//
// visible
// visible
// hidden
// hidden
// veryHidden
// veryHidden
//
//
// For example, hide Sheet1:
// For example, hide Sheet1:
//
//
// err := f.SetSheetVisible("Sheet1", false)
// err := f.SetSheetVisible("Sheet1", false)
//
func ( f * File ) SetSheetVisible ( sheet string , visible bool ) error {
func ( f * File ) SetSheetVisible ( sheet string , visible bool ) error {
sheet = trimSheetName ( sheet )
sheet = trimSheetName ( sheet )
content := f . workbookReader ( )
content := f . workbookReader ( )
@ -688,50 +685,50 @@ func parseFormatPanesSet(formatSet string) (*formatPanes, error) {
// activePane defines the pane that is active. The possible values for this
// activePane defines the pane that is active. The possible values for this
// attribute are defined in the following table:
// attribute are defined in the following table:
//
//
// Enumeration Value | Description
// Enumeration Value | Description
// --------------------------------+-------------------------------------------------------------
// --------------------------------+-------------------------------------------------------------
// bottomLeft (Bottom Left Pane) | Bottom left pane, when both vertical and horizontal
// bottomLeft (Bottom Left Pane) | Bottom left pane, when both vertical and horizontal
// | splits are applied.
// | splits are applied.
// |
// |
// | This value is also used when only a horizontal split has
// | This value is also used when only a horizontal split has
// | been applied, dividing the pane into upper and lower
// | been applied, dividing the pane into upper and lower
// | regions. In that case, this value specifies the bottom
// | regions. In that case, this value specifies the bottom
// | pane.
// | pane.
// |
// |
// bottomRight (Bottom Right Pane) | Bottom right pane, when both vertical and horizontal
// bottomRight (Bottom Right Pane) | Bottom right pane, when both vertical and horizontal
// | splits are applied.
// | splits are applied.
// |
// |
// topLeft (Top Left Pane) | Top left pane, when both vertical and horizontal splits
// topLeft (Top Left Pane) | Top left pane, when both vertical and horizontal splits
// | are applied.
// | are applied.
// |
// |
// | This value is also used when only a horizontal split has
// | This value is also used when only a horizontal split has
// | been applied, dividing the pane into upper and lower
// | been applied, dividing the pane into upper and lower
// | regions. In that case, this value specifies the top pane.
// | regions. In that case, this value specifies the top pane.
// |
// |
// | This value is also used when only a vertical split has
// | This value is also used when only a vertical split has
// | been applied, dividing the pane into right and left
// | been applied, dividing the pane into right and left
// | regions. In that case, this value specifies the left pane
// | regions. In that case, this value specifies the left pane
// |
// |
// topRight (Top Right Pane) | Top right pane, when both vertical and horizontal
// topRight (Top Right Pane) | Top right pane, when both vertical and horizontal
// | splits are applied.
// | splits are applied.
// |
// |
// | This value is also used when only a vertical split has
// | This value is also used when only a vertical split has
// | been applied, dividing the pane into right and left
// | been applied, dividing the pane into right and left
// | regions. In that case, this value specifies the right
// | regions. In that case, this value specifies the right
// | pane.
// | pane.
//
//
// Pane state type is restricted to the values supported currently listed in the following table:
// Pane state type is restricted to the values supported currently listed in the following table:
//
//
// Enumeration Value | Description
// Enumeration Value | Description
// --------------------------------+-------------------------------------------------------------
// --------------------------------+-------------------------------------------------------------
// frozen (Frozen) | Panes are frozen, but were not split being frozen. In
// frozen (Frozen) | Panes are frozen, but were not split being frozen. In
// | this state, when the panes are unfrozen again, a single
// | this state, when the panes are unfrozen again, a single
// | pane results, with no split.
// | pane results, with no split.
// |
// |
// | In this state, the split bars are not adjustable.
// | In this state, the split bars are not adjustable.
// |
// |
// split (Split) | Panes are split, but not frozen. In this state, the split
// split (Split) | Panes are split, but not frozen. In this state, the split
// | bars are adjustable by the user.
// | bars are adjustable by the user.
//
//
// x_split (Horizontal Split Position): Horizontal position of the split, in
// x_split (Horizontal Split Position): Horizontal position of the split, in
// 1/20th of a point; 0 (zero) if none. If the pane is frozen, this value
// 1/20th of a point; 0 (zero) if none. If the pane is frozen, this value
@ -751,22 +748,21 @@ func parseFormatPanesSet(formatSet string) (*formatPanes, error) {
// An example of how to freeze column A in the Sheet1 and set the active cell on
// An example of how to freeze column A in the Sheet1 and set the active cell on
// Sheet1!K16:
// Sheet1!K16:
//
//
// f.SetPanes("Sheet1", `{"freeze":true,"split":false,"x_split":1,"y_split":0,"top_left_cell":"B1","active_pane":"topRight","panes":[{"sqref":"K16","active_cell":"K16","pane":"topRight"}]}`)
// f.SetPanes("Sheet1", `{"freeze":true,"split":false,"x_split":1,"y_split":0,"top_left_cell":"B1","active_pane":"topRight","panes":[{"sqref":"K16","active_cell":"K16","pane":"topRight"}]}`)
//
//
// An example of how to freeze rows 1 to 9 in the Sheet1 and set the active cell
// An example of how to freeze rows 1 to 9 in the Sheet1 and set the active cell
// ranges on Sheet1!A11:XFD11:
// ranges on Sheet1!A11:XFD11:
//
//
// f.SetPanes("Sheet1", `{"freeze":true,"split":false,"x_split":0,"y_split":9,"top_left_cell":"A34","active_pane":"bottomLeft","panes":[{"sqref":"A11:XFD11","active_cell":"A11","pane":"bottomLeft"}]}`)
// f.SetPanes("Sheet1", `{"freeze":true,"split":false,"x_split":0,"y_split":9,"top_left_cell":"A34","active_pane":"bottomLeft","panes":[{"sqref":"A11:XFD11","active_cell":"A11","pane":"bottomLeft"}]}`)
//
//
// An example of how to create split panes in the Sheet1 and set the active cell
// An example of how to create split panes in the Sheet1 and set the active cell
// on Sheet1!J60:
// on Sheet1!J60:
//
//
// f.SetPanes("Sheet1", `{"freeze":false,"split":true,"x_split":3270,"y_split":1800,"top_left_cell":"N57","active_pane":"bottomLeft","panes":[{"sqref":"I36","active_cell":"I36"},{"sqref":"G33","active_cell":"G33","pane":"topRight"},{"sqref":"J60","active_cell":"J60","pane":"bottomLeft"},{"sqref":"O60","active_cell":"O60","pane":"bottomRight"}]}`)
// f.SetPanes("Sheet1", `{"freeze":false,"split":true,"x_split":3270,"y_split":1800,"top_left_cell":"N57","active_pane":"bottomLeft","panes":[{"sqref":"I36","active_cell":"I36"},{"sqref":"G33","active_cell":"G33","pane":"topRight"},{"sqref":"J60","active_cell":"J60","pane":"bottomLeft"},{"sqref":"O60","active_cell":"O60","pane":"bottomRight"}]}`)
//
//
// An example of how to unfreeze and remove all panes on Sheet1:
// An example of how to unfreeze and remove all panes on Sheet1:
//
//
// f.SetPanes("Sheet1", `{"freeze":false,"split":false}`)
// f.SetPanes("Sheet1", `{"freeze":false,"split":false}`)
//
func ( f * File ) SetPanes ( sheet , panes string ) error {
func ( f * File ) SetPanes ( sheet , panes string ) error {
fs , _ := parseFormatPanesSet ( panes )
fs , _ := parseFormatPanesSet ( panes )
ws , err := f . workSheetReader ( sheet )
ws , err := f . workSheetReader ( sheet )
@ -806,8 +802,7 @@ func (f *File) SetPanes(sheet, panes string) error {
// GetSheetVisible provides a function to get worksheet visible by given worksheet
// GetSheetVisible provides a function to get worksheet visible by given worksheet
// name. For example, get visible state of Sheet1:
// name. For example, get visible state of Sheet1:
//
//
// f.GetSheetVisible("Sheet1")
// f.GetSheetVisible("Sheet1")
//
func ( f * File ) GetSheetVisible ( sheet string ) bool {
func ( f * File ) GetSheetVisible ( sheet string ) bool {
content , name , visible := f . workbookReader ( ) , trimSheetName ( sheet ) , false
content , name , visible := f . workbookReader ( ) , trimSheetName ( sheet ) , false
for k , v := range content . Sheets . Sheet {
for k , v := range content . Sheets . Sheet {
@ -828,13 +823,12 @@ func (f *File) GetSheetVisible(sheet string) bool {
//
//
// An example of search the coordinates of the value of "100" on Sheet1:
// An example of search the coordinates of the value of "100" on Sheet1:
//
//
// result, err := f.SearchSheet("Sheet1", "100")
// result, err := f.SearchSheet("Sheet1", "100")
//
//
// An example of search the coordinates where the numerical value in the range
// An example of search the coordinates where the numerical value in the range
// of "0-9" of Sheet1 is described:
// of "0-9" of Sheet1 is described:
//
//
// result, err := f.SearchSheet("Sheet1", "[0-9]", true)
// result, err := f.SearchSheet("Sheet1", "[0-9]", true)
//
func ( f * File ) SearchSheet ( sheet , value string , reg ... bool ) ( [ ] string , error ) {
func ( f * File ) SearchSheet ( sheet , value string , reg ... bool ) ( [ ] string , error ) {
var (
var (
regSearch bool
regSearch bool
@ -961,95 +955,95 @@ func attrValToBool(name string, attrs []xml.Attr) (val bool, err error) {
//
//
// Headers and footers are specified using the following settings fields:
// Headers and footers are specified using the following settings fields:
//
//
// Fields | Description
// Fields | Description
// ------------------+-----------------------------------------------------------
// ------------------+-----------------------------------------------------------
// AlignWithMargins | Align header footer margins with page margins
// AlignWithMargins | Align header footer margins with page margins
// DifferentFirst | Different first-page header and footer indicator
// DifferentFirst | Different first-page header and footer indicator
// DifferentOddEven | Different odd and even page headers and footers indicator
// DifferentOddEven | Different odd and even page headers and footers indicator
// ScaleWithDoc | Scale header and footer with document scaling
// ScaleWithDoc | Scale header and footer with document scaling
// OddFooter | Odd Page Footer
// OddFooter | Odd Page Footer
// OddHeader | Odd Header
// OddHeader | Odd Header
// EvenFooter | Even Page Footer
// EvenFooter | Even Page Footer
// EvenHeader | Even Page Header
// EvenHeader | Even Page Header
// FirstFooter | First Page Footer
// FirstFooter | First Page Footer
// FirstHeader | First Page Header
// FirstHeader | First Page Header
//
//
// The following formatting codes can be used in 6 string type fields:
// The following formatting codes can be used in 6 string type fields:
// OddHeader, OddFooter, EvenHeader, EvenFooter, FirstFooter, FirstHeader
// OddHeader, OddFooter, EvenHeader, EvenFooter, FirstFooter, FirstHeader
//
//
// Formatting Code | Description
// Formatting Code | Description
// ------------------------+-------------------------------------------------------------------------
// ------------------------+-------------------------------------------------------------------------
// && | The character "&"
// && | The character "&"
// |
// |
// &font-size | Size of the text font, where font-size is a decimal font size in points
// &font-size | Size of the text font, where font-size is a decimal font size in points
// |
// |
// &"font name,font type" | A text font-name string, font name, and a text font-type string,
// &"font name,font type" | A text font-name string, font name, and a text font-type string,
// | font type
// | font type
// |
// |
// &"-,Regular" | Regular text format. Toggles bold and italic modes to off
// &"-,Regular" | Regular text format. Toggles bold and italic modes to off
// |
// |
// &A | Current worksheet's tab name
// &A | Current worksheet's tab name
// |
// |
// &B or &"-,Bold" | Bold text format, from off to on, or vice versa. The default mode is off
// &B or &"-,Bold" | Bold text format, from off to on, or vice versa. The default mode is off
// |
// |
// &D | Current date
// &D | Current date
// |
// |
// &C | Center section
// &C | Center section
// |
// |
// &E | Double-underline text format
// &E | Double-underline text format
// |
// |
// &F | Current workbook's file name
// &F | Current workbook's file name
// |
// |
// &G | Drawing object as background
// &G | Drawing object as background
// |
// |
// &H | Shadow text format
// &H | Shadow text format
// |
// |
// &I or &"-,Italic" | Italic text format
// &I or &"-,Italic" | Italic text format
// |
// |
// &K | Text font color
// &K | Text font color
// |
// |
// | An RGB Color is specified as RRGGBB
// | An RGB Color is specified as RRGGBB
// |
// |
// | A Theme Color is specified as TTSNNN where TT is the theme color Id,
// | A Theme Color is specified as TTSNNN where TT is the theme color Id,
// | S is either "+" or "-" of the tint/shade value, and NNN is the
// | S is either "+" or "-" of the tint/shade value, and NNN is the
// | tint/shade value
// | tint/shade value
// |
// |
// &L | Left section
// &L | Left section
// |
// |
// &N | Total number of pages
// &N | Total number of pages
// |
// |
// &O | Outline text format
// &O | Outline text format
// |
// |
// &P[[+|-]n] | Without the optional suffix, the current page number in decimal
// &P[[+|-]n] | Without the optional suffix, the current page number in decimal
// |
// |
// &R | Right section
// &R | Right section
// |
// |
// &S | Strikethrough text format
// &S | Strikethrough text format
// |
// |
// &T | Current time
// &T | Current time
// |
// |
// &U | Single-underline text format. If double-underline mode is on, the next
// &U | Single-underline text format. If double-underline mode is on, the next
// | occurrence in a section specifier toggles double-underline mode to off;
// | occurrence in a section specifier toggles double-underline mode to off;
// | otherwise, it toggles single-underline mode, from off to on, or vice
// | otherwise, it toggles single-underline mode, from off to on, or vice
// | versa. The default mode is off
// | versa. The default mode is off
// |
// |
// &X | Superscript text format
// &X | Superscript text format
// |
// |
// &Y | Subscript text format
// &Y | Subscript text format
// |
// |
// &Z | Current workbook's file path
// &Z | Current workbook's file path
//
//
// For example:
// For example:
//
//
// err := f.SetHeaderFooter("Sheet1", &excelize.FormatHeaderFooter{
// err := f.SetHeaderFooter("Sheet1", &excelize.FormatHeaderFooter{
// DifferentFirst: true,
// DifferentFirst: true,
// DifferentOddEven: true,
// DifferentOddEven: true,
// OddHeader: "&R&P",
// OddHeader: "&R&P",
// OddFooter: "&C&F",
// OddFooter: "&C&F",
// EvenHeader: "&L&P",
// EvenHeader: "&L&P",
// EvenFooter: "&L&D&R&T",
// EvenFooter: "&L&D&R&T",
// FirstHeader: `&CCenter &"-,Bold"Bold&"-,Regular"HeaderU+000A&D`,
// FirstHeader: `&CCenter &"-,Bold"Bold&"-,Regular"HeaderU+000A&D`,
// })
// })
//
//
// This example shows:
// This example shows:
//
//
@ -1071,7 +1065,6 @@ func attrValToBool(name string, attrs []xml.Attr) (val bool, err error) {
// that same page
// that same page
//
//
// - No footer on the first page
// - No footer on the first page
//
func ( f * File ) SetHeaderFooter ( sheet string , settings * FormatHeaderFooter ) error {
func ( f * File ) SetHeaderFooter ( sheet string , settings * FormatHeaderFooter ) error {
ws , err := f . workSheetReader ( sheet )
ws , err := f . workSheetReader ( sheet )
if err != nil {
if err != nil {
@ -1112,12 +1105,11 @@ func (f *File) SetHeaderFooter(sheet string, settings *FormatHeaderFooter) error
// specified, will be using the XOR algorithm as default. For example, protect
// specified, will be using the XOR algorithm as default. For example, protect
// Sheet1 with protection settings:
// Sheet1 with protection settings:
//
//
// err := f.ProtectSheet("Sheet1", &excelize.FormatSheetProtection{
// err := f.ProtectSheet("Sheet1", &excelize.FormatSheetProtection{
// AlgorithmName: "SHA-512",
// AlgorithmName: "SHA-512",
// Password: "password",
// Password: "password",
// EditScenarios: false,
// EditScenarios: false,
// })
// })
//
func ( f * File ) ProtectSheet ( sheet string , settings * FormatSheetProtection ) error {
func ( f * File ) ProtectSheet ( sheet string , settings * FormatSheetProtection ) error {
ws , err := f . workSheetReader ( sheet )
ws , err := f . workSheetReader ( sheet )
if err != nil {
if err != nil {
@ -1377,135 +1369,134 @@ func (p *PageLayoutScale) getPageLayout(ps *xlsxPageSetUp) {
//
//
// Available options:
// Available options:
//
//
// BlackAndWhite(bool)
// BlackAndWhite(bool)
// FirstPageNumber(uint)
// FirstPageNumber(uint)
// PageLayoutOrientation(string)
// PageLayoutOrientation(string)
// PageLayoutPaperSize(int)
// PageLayoutPaperSize(int)
// FitToHeight(int)
// FitToHeight(int)
// FitToWidth(int)
// FitToWidth(int)
// PageLayoutScale(uint)
// PageLayoutScale(uint)
//
//
// The following shows the paper size sorted by excelize index number:
// The following shows the paper size sorted by excelize index number:
//
//
// Index | Paper Size
// Index | Paper Size
// -------+-----------------------------------------------
// -------+-----------------------------------------------
// 1 | Letter paper (8.5 in. by 11 in.)
// 1 | Letter paper (8.5 in. by 11 in.)
// 2 | Letter small paper (8.5 in. by 11 in.)
// 2 | Letter small paper (8.5 in. by 11 in.)
// 3 | Tabloid paper (11 in. by 17 in.)
// 3 | Tabloid paper (11 in. by 17 in.)
// 4 | Ledger paper (17 in. by 11 in.)
// 4 | Ledger paper (17 in. by 11 in.)
// 5 | Legal paper (8.5 in. by 14 in.)
// 5 | Legal paper (8.5 in. by 14 in.)
// 6 | Statement paper (5.5 in. by 8.5 in.)
// 6 | Statement paper (5.5 in. by 8.5 in.)
// 7 | Executive paper (7.25 in. by 10.5 in.)
// 7 | Executive paper (7.25 in. by 10.5 in.)
// 8 | A3 paper (297 mm by 420 mm)
// 8 | A3 paper (297 mm by 420 mm)
// 9 | A4 paper (210 mm by 297 mm)
// 9 | A4 paper (210 mm by 297 mm)
// 10 | A4 small paper (210 mm by 297 mm)
// 10 | A4 small paper (210 mm by 297 mm)
// 11 | A5 paper (148 mm by 210 mm)
// 11 | A5 paper (148 mm by 210 mm)
// 12 | B4 paper (250 mm by 353 mm)
// 12 | B4 paper (250 mm by 353 mm)
// 13 | B5 paper (176 mm by 250 mm)
// 13 | B5 paper (176 mm by 250 mm)
// 14 | Folio paper (8.5 in. by 13 in.)
// 14 | Folio paper (8.5 in. by 13 in.)
// 15 | Quarto paper (215 mm by 275 mm)
// 15 | Quarto paper (215 mm by 275 mm)
// 16 | Standard paper (10 in. by 14 in.)
// 16 | Standard paper (10 in. by 14 in.)
// 17 | Standard paper (11 in. by 17 in.)
// 17 | Standard paper (11 in. by 17 in.)
// 18 | Note paper (8.5 in. by 11 in.)
// 18 | Note paper (8.5 in. by 11 in.)
// 19 | #9 envelope (3.875 in. by 8.875 in.)
// 19 | #9 envelope (3.875 in. by 8.875 in.)
// 20 | #10 envelope (4.125 in. by 9.5 in.)
// 20 | #10 envelope (4.125 in. by 9.5 in.)
// 21 | #11 envelope (4.5 in. by 10.375 in.)
// 21 | #11 envelope (4.5 in. by 10.375 in.)
// 22 | #12 envelope (4.75 in. by 11 in.)
// 22 | #12 envelope (4.75 in. by 11 in.)
// 23 | #14 envelope (5 in. by 11.5 in.)
// 23 | #14 envelope (5 in. by 11.5 in.)
// 24 | C paper (17 in. by 22 in.)
// 24 | C paper (17 in. by 22 in.)
// 25 | D paper (22 in. by 34 in.)
// 25 | D paper (22 in. by 34 in.)
// 26 | E paper (34 in. by 44 in.)
// 26 | E paper (34 in. by 44 in.)
// 27 | DL envelope (110 mm by 220 mm)
// 27 | DL envelope (110 mm by 220 mm)
// 28 | C5 envelope (162 mm by 229 mm)
// 28 | C5 envelope (162 mm by 229 mm)
// 29 | C3 envelope (324 mm by 458 mm)
// 29 | C3 envelope (324 mm by 458 mm)
// 30 | C4 envelope (229 mm by 324 mm)
// 30 | C4 envelope (229 mm by 324 mm)
// 31 | C6 envelope (114 mm by 162 mm)
// 31 | C6 envelope (114 mm by 162 mm)
// 32 | C65 envelope (114 mm by 229 mm)
// 32 | C65 envelope (114 mm by 229 mm)
// 33 | B4 envelope (250 mm by 353 mm)
// 33 | B4 envelope (250 mm by 353 mm)
// 34 | B5 envelope (176 mm by 250 mm)
// 34 | B5 envelope (176 mm by 250 mm)
// 35 | B6 envelope (176 mm by 125 mm)
// 35 | B6 envelope (176 mm by 125 mm)
// 36 | Italy envelope (110 mm by 230 mm)
// 36 | Italy envelope (110 mm by 230 mm)
// 37 | Monarch envelope (3.875 in. by 7.5 in.).
// 37 | Monarch envelope (3.875 in. by 7.5 in.).
// 38 | 6 3/4 envelope (3.625 in. by 6.5 in.)
// 38 | 6 3/4 envelope (3.625 in. by 6.5 in.)
// 39 | US standard fanfold (14.875 in. by 11 in.)
// 39 | US standard fanfold (14.875 in. by 11 in.)
// 40 | German standard fanfold (8.5 in. by 12 in.)
// 40 | German standard fanfold (8.5 in. by 12 in.)
// 41 | German legal fanfold (8.5 in. by 13 in.)
// 41 | German legal fanfold (8.5 in. by 13 in.)
// 42 | ISO B4 (250 mm by 353 mm)
// 42 | ISO B4 (250 mm by 353 mm)
// 43 | Japanese postcard (100 mm by 148 mm)
// 43 | Japanese postcard (100 mm by 148 mm)
// 44 | Standard paper (9 in. by 11 in.)
// 44 | Standard paper (9 in. by 11 in.)
// 45 | Standard paper (10 in. by 11 in.)
// 45 | Standard paper (10 in. by 11 in.)
// 46 | Standard paper (15 in. by 11 in.)
// 46 | Standard paper (15 in. by 11 in.)
// 47 | Invite envelope (220 mm by 220 mm)
// 47 | Invite envelope (220 mm by 220 mm)
// 50 | Letter extra paper (9.275 in. by 12 in.)
// 50 | Letter extra paper (9.275 in. by 12 in.)
// 51 | Legal extra paper (9.275 in. by 15 in.)
// 51 | Legal extra paper (9.275 in. by 15 in.)
// 52 | Tabloid extra paper (11.69 in. by 18 in.)
// 52 | Tabloid extra paper (11.69 in. by 18 in.)
// 53 | A4 extra paper (236 mm by 322 mm)
// 53 | A4 extra paper (236 mm by 322 mm)
// 54 | Letter transverse paper (8.275 in. by 11 in.)
// 54 | Letter transverse paper (8.275 in. by 11 in.)
// 55 | A4 transverse paper (210 mm by 297 mm)
// 55 | A4 transverse paper (210 mm by 297 mm)
// 56 | Letter extra transverse paper (9.275 in. by 12 in.)
// 56 | Letter extra transverse paper (9.275 in. by 12 in.)
// 57 | SuperA/SuperA/A4 paper (227 mm by 356 mm)
// 57 | SuperA/SuperA/A4 paper (227 mm by 356 mm)
// 58 | SuperB/SuperB/A3 paper (305 mm by 487 mm)
// 58 | SuperB/SuperB/A3 paper (305 mm by 487 mm)
// 59 | Letter plus paper (8.5 in. by 12.69 in.)
// 59 | Letter plus paper (8.5 in. by 12.69 in.)
// 60 | A4 plus paper (210 mm by 330 mm)
// 60 | A4 plus paper (210 mm by 330 mm)
// 61 | A5 transverse paper (148 mm by 210 mm)
// 61 | A5 transverse paper (148 mm by 210 mm)
// 62 | JIS B5 transverse paper (182 mm by 257 mm)
// 62 | JIS B5 transverse paper (182 mm by 257 mm)
// 63 | A3 extra paper (322 mm by 445 mm)
// 63 | A3 extra paper (322 mm by 445 mm)
// 64 | A5 extra paper (174 mm by 235 mm)
// 64 | A5 extra paper (174 mm by 235 mm)
// 65 | ISO B5 extra paper (201 mm by 276 mm)
// 65 | ISO B5 extra paper (201 mm by 276 mm)
// 66 | A2 paper (420 mm by 594 mm)
// 66 | A2 paper (420 mm by 594 mm)
// 67 | A3 transverse paper (297 mm by 420 mm)
// 67 | A3 transverse paper (297 mm by 420 mm)
// 68 | A3 extra transverse paper (322 mm by 445 mm)
// 68 | A3 extra transverse paper (322 mm by 445 mm)
// 69 | Japanese Double Postcard (200 mm x 148 mm)
// 69 | Japanese Double Postcard (200 mm x 148 mm)
// 70 | A6 (105 mm x 148 mm)
// 70 | A6 (105 mm x 148 mm)
// 71 | Japanese Envelope Kaku #2
// 71 | Japanese Envelope Kaku #2
// 72 | Japanese Envelope Kaku #3
// 72 | Japanese Envelope Kaku #3
// 73 | Japanese Envelope Chou #3
// 73 | Japanese Envelope Chou #3
// 74 | Japanese Envelope Chou #4
// 74 | Japanese Envelope Chou #4
// 75 | Letter Rotated (11in x 8 1/2 11 in)
// 75 | Letter Rotated (11in x 8 1/2 11 in)
// 76 | A3 Rotated (420 mm x 297 mm)
// 76 | A3 Rotated (420 mm x 297 mm)
// 77 | A4 Rotated (297 mm x 210 mm)
// 77 | A4 Rotated (297 mm x 210 mm)
// 78 | A5 Rotated (210 mm x 148 mm)
// 78 | A5 Rotated (210 mm x 148 mm)
// 79 | B4 (JIS) Rotated (364 mm x 257 mm)
// 79 | B4 (JIS) Rotated (364 mm x 257 mm)
// 80 | B5 (JIS) Rotated (257 mm x 182 mm)
// 80 | B5 (JIS) Rotated (257 mm x 182 mm)
// 81 | Japanese Postcard Rotated (148 mm x 100 mm)
// 81 | Japanese Postcard Rotated (148 mm x 100 mm)
// 82 | Double Japanese Postcard Rotated (148 mm x 200 mm)
// 82 | Double Japanese Postcard Rotated (148 mm x 200 mm)
// 83 | A6 Rotated (148 mm x 105 mm)
// 83 | A6 Rotated (148 mm x 105 mm)
// 84 | Japanese Envelope Kaku #2 Rotated
// 84 | Japanese Envelope Kaku #2 Rotated
// 85 | Japanese Envelope Kaku #3 Rotated
// 85 | Japanese Envelope Kaku #3 Rotated
// 86 | Japanese Envelope Chou #3 Rotated
// 86 | Japanese Envelope Chou #3 Rotated
// 87 | Japanese Envelope Chou #4 Rotated
// 87 | Japanese Envelope Chou #4 Rotated
// 88 | B6 (JIS) (128 mm x 182 mm)
// 88 | B6 (JIS) (128 mm x 182 mm)
// 89 | B6 (JIS) Rotated (182 mm x 128 mm)
// 89 | B6 (JIS) Rotated (182 mm x 128 mm)
// 90 | (12 in x 11 in)
// 90 | (12 in x 11 in)
// 91 | Japanese Envelope You #4
// 91 | Japanese Envelope You #4
// 92 | Japanese Envelope You #4 Rotated
// 92 | Japanese Envelope You #4 Rotated
// 93 | PRC 16K (146 mm x 215 mm)
// 93 | PRC 16K (146 mm x 215 mm)
// 94 | PRC 32K (97 mm x 151 mm)
// 94 | PRC 32K (97 mm x 151 mm)
// 95 | PRC 32K(Big) (97 mm x 151 mm)
// 95 | PRC 32K(Big) (97 mm x 151 mm)
// 96 | PRC Envelope #1 (102 mm x 165 mm)
// 96 | PRC Envelope #1 (102 mm x 165 mm)
// 97 | PRC Envelope #2 (102 mm x 176 mm)
// 97 | PRC Envelope #2 (102 mm x 176 mm)
// 98 | PRC Envelope #3 (125 mm x 176 mm)
// 98 | PRC Envelope #3 (125 mm x 176 mm)
// 99 | PRC Envelope #4 (110 mm x 208 mm)
// 99 | PRC Envelope #4 (110 mm x 208 mm)
// 100 | PRC Envelope #5 (110 mm x 220 mm)
// 100 | PRC Envelope #5 (110 mm x 220 mm)
// 101 | PRC Envelope #6 (120 mm x 230 mm)
// 101 | PRC Envelope #6 (120 mm x 230 mm)
// 102 | PRC Envelope #7 (160 mm x 230 mm)
// 102 | PRC Envelope #7 (160 mm x 230 mm)
// 103 | PRC Envelope #8 (120 mm x 309 mm)
// 103 | PRC Envelope #8 (120 mm x 309 mm)
// 104 | PRC Envelope #9 (229 mm x 324 mm)
// 104 | PRC Envelope #9 (229 mm x 324 mm)
// 105 | PRC Envelope #10 (324 mm x 458 mm)
// 105 | PRC Envelope #10 (324 mm x 458 mm)
// 106 | PRC 16K Rotated
// 106 | PRC 16K Rotated
// 107 | PRC 32K Rotated
// 107 | PRC 32K Rotated
// 108 | PRC 32K(Big) Rotated
// 108 | PRC 32K(Big) Rotated
// 109 | PRC Envelope #1 Rotated (165 mm x 102 mm)
// 109 | PRC Envelope #1 Rotated (165 mm x 102 mm)
// 110 | PRC Envelope #2 Rotated (176 mm x 102 mm)
// 110 | PRC Envelope #2 Rotated (176 mm x 102 mm)
// 111 | PRC Envelope #3 Rotated (176 mm x 125 mm)
// 111 | PRC Envelope #3 Rotated (176 mm x 125 mm)
// 112 | PRC Envelope #4 Rotated (208 mm x 110 mm)
// 112 | PRC Envelope #4 Rotated (208 mm x 110 mm)
// 113 | PRC Envelope #5 Rotated (220 mm x 110 mm)
// 113 | PRC Envelope #5 Rotated (220 mm x 110 mm)
// 114 | PRC Envelope #6 Rotated (230 mm x 120 mm)
// 114 | PRC Envelope #6 Rotated (230 mm x 120 mm)
// 115 | PRC Envelope #7 Rotated (230 mm x 160 mm)
// 115 | PRC Envelope #7 Rotated (230 mm x 160 mm)
// 116 | PRC Envelope #8 Rotated (309 mm x 120 mm)
// 116 | PRC Envelope #8 Rotated (309 mm x 120 mm)
// 117 | PRC Envelope #9 Rotated (324 mm x 229 mm)
// 117 | PRC Envelope #9 Rotated (324 mm x 229 mm)
// 118 | PRC Envelope #10 Rotated (458 mm x 324 mm)
// 118 | PRC Envelope #10 Rotated (458 mm x 324 mm)
//
func ( f * File ) SetPageLayout ( sheet string , opts ... PageLayoutOption ) error {
func ( f * File ) SetPageLayout ( sheet string , opts ... PageLayoutOption ) error {
s , err := f . workSheetReader ( sheet )
s , err := f . workSheetReader ( sheet )
if err != nil {
if err != nil {
@ -1526,10 +1517,11 @@ func (f *File) SetPageLayout(sheet string, opts ...PageLayoutOption) error {
// GetPageLayout provides a function to gets worksheet page layout.
// GetPageLayout provides a function to gets worksheet page layout.
//
//
// Available options:
// Available options:
// PageLayoutOrientation(string)
//
// PageLayoutPaperSize(int)
// PageLayoutOrientation(string)
// FitToHeight(int)
// PageLayoutPaperSize(int)
// FitToWidth(int)
// FitToHeight(int)
// FitToWidth(int)
func ( f * File ) GetPageLayout ( sheet string , opts ... PageLayoutOptionPtr ) error {
func ( f * File ) GetPageLayout ( sheet string , opts ... PageLayoutOptionPtr ) error {
s , err := f . workSheetReader ( sheet )
s , err := f . workSheetReader ( sheet )
if err != nil {
if err != nil {
@ -1547,13 +1539,12 @@ func (f *File) GetPageLayout(sheet string, opts ...PageLayoutOptionPtr) error {
// or worksheet. If not specified scope, the default scope is workbook.
// or worksheet. If not specified scope, the default scope is workbook.
// For example:
// For example:
//
//
// f.SetDefinedName(&excelize.DefinedName{
// f.SetDefinedName(&excelize.DefinedName{
// Name: "Amount",
// Name: "Amount",
// RefersTo: "Sheet1!$A$2:$D$5",
// RefersTo: "Sheet1!$A$2:$D$5",
// Comment: "defined name comment",
// Comment: "defined name comment",
// Scope: "Sheet2",
// Scope: "Sheet2",
// })
// })
//
func ( f * File ) SetDefinedName ( definedName * DefinedName ) error {
func ( f * File ) SetDefinedName ( definedName * DefinedName ) error {
wb := f . workbookReader ( )
wb := f . workbookReader ( )
d := xlsxDefinedName {
d := xlsxDefinedName {
@ -1589,11 +1580,10 @@ func (f *File) SetDefinedName(definedName *DefinedName) error {
// workbook or worksheet. If not specified scope, the default scope is
// workbook or worksheet. If not specified scope, the default scope is
// workbook. For example:
// workbook. For example:
//
//
// f.DeleteDefinedName(&excelize.DefinedName{
// f.DeleteDefinedName(&excelize.DefinedName{
// Name: "Amount",
// Name: "Amount",
// Scope: "Sheet2",
// Scope: "Sheet2",
// })
// })
//
func ( f * File ) DeleteDefinedName ( definedName * DefinedName ) error {
func ( f * File ) DeleteDefinedName ( definedName * DefinedName ) error {
wb := f . workbookReader ( )
wb := f . workbookReader ( )
if wb . DefinedNames != nil {
if wb . DefinedNames != nil {