Class HSSFWorkbook
- java.lang.Object
- 
- org.apache.poi.POIDocument
- 
- org.apache.poi.hssf.usermodel.HSSFWorkbook
 
 
- 
- All Implemented Interfaces:
- Closeable,- AutoCloseable,- Iterable<Sheet>,- Workbook
 
 public final class HSSFWorkbook extends POIDocument implements Workbook High level representation of a workbook. This is the first object most users will construct whether they are reading or writing a workbook. It is also the top level object for creating new sheets/etc.- See Also:
- InternalWorkbook,- HSSFSheet
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected List<HSSFSheet>_sheetsthis holds the HSSFSheet objects attached to this workbookstatic intINITIAL_CAPACITYused for compile-time performance/memory optimization.- 
Fields inherited from interface org.apache.poi.ss.usermodel.WorkbookMAX_SENSITIVE_SHEET_NAME_LEN, PICTURE_TYPE_DIB, PICTURE_TYPE_EMF, PICTURE_TYPE_JPEG, PICTURE_TYPE_PICT, PICTURE_TYPE_PNG, PICTURE_TYPE_WMF
 
- 
 - 
Constructor SummaryConstructors Constructor Description HSSFWorkbook()Creates new HSSFWorkbook from scratch (start here!)HSSFWorkbook(InputStream s)Companion to HSSFWorkbook(POIFSFileSystem), this constructs the POI filesystem around yourInputStream, including all nodes.HSSFWorkbook(InputStream s, boolean preserveNodes)Companion to HSSFWorkbook(POIFSFileSystem), this constructs the POI filesystem around yourInputStream.HSSFWorkbook(DirectoryNode directory, boolean preserveNodes)given a POI POIFSFileSystem object, and a specific directory within it, read in its Workbook and populate the high and low level models.HSSFWorkbook(DirectoryNode directory, POIFSFileSystem fs, boolean preserveNodes)given a POI POIFSFileSystem object, and a specific directory within it, read in its Workbook and populate the high and low level models.HSSFWorkbook(POIFSFileSystem fs)Given a POI POIFSFileSystem object, read in its Workbook along with all related nodes, and populate the high and low level models.HSSFWorkbook(POIFSFileSystem fs, boolean preserveNodes)Given a POI POIFSFileSystem object, read in its Workbook and populate the high and low level models.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description intaddOlePackage(byte[] oleData, String label, String fileName, String command)Adds an OLE package manager object with the given content to the sheetintaddOlePackage(POIFSFileSystem poiData, String label, String fileName, String command)Adds an OLE package manager object with the given POIFS to the sheetintaddPicture(byte[] pictureData, int format)Adds a picture to the workbook.voidaddToolPack(UDFFinder toolpack)Register a new toolpack in this workbook.booleanchangeExternalReference(String oldUrl, String newUrl)Changes an external referenced file to another file.HSSFSheetcloneSheet(int sheetIndex)create an HSSFSheet from an existing sheet in the HSSFWorkbook.voidclose()Closes the underlyingPOIFSFileSystemfrom which the Workbook was read, if any.static HSSFWorkbookcreate(InternalWorkbook book)HSSFCellStylecreateCellStyle()Create a new Cell style and add it to the workbook's style table.HSSFDataFormatcreateDataFormat()Returns the instance of HSSFDataFormat for this workbook.HSSFEvaluationWorkbookcreateEvaluationWorkbook()HSSFFontcreateFont()create a new Font and add it to the workbook's font tableHSSFNamecreateName()creates a new named range and add it to the modelHSSFSheetcreateSheet()create an HSSFSheet for this HSSFWorkbook, adds it to the sheets and returns the high level representation.HSSFSheetcreateSheet(String sheetname)Create a new sheet for this Workbook and return the high level representation.voiddumpDrawingGroupRecords(boolean fat)Spits out a list of all the drawing records in the workbook.HSSFFontfindFont(boolean bold, short color, short fontHeight, String name, boolean italic, boolean strikeout, short typeOffset, byte underline)Finds a font that matches the one with the supplied attributesintgetActiveSheetIndex()gets the tab whose data is actually seen when the sheet is opened.List<HSSFObjectData>getAllEmbeddedObjects()Gets all embedded OLE2 objects from the Workbook.List<HSSFName>getAllNames()Returns all defined names.List<HSSFPictureData>getAllPictures()Gets all pictures from the Workbook.booleangetBackupFlag()determine whether the Excel GUI will backup the workbook when saving.byte[]getBytes()Method getBytes - get the bytes of just the HSSF portions of the XLS file.CellReferenceTypegetCellReferenceType()HSSFCellStylegetCellStyleAt(int idx)get the cell style object at the given indexHSSFCreationHelpergetCreationHelper()Returns an object that handles instantiating concrete classes of the various instances one needs for HSSF and XSSF.HSSFPalettegetCustomPalette()EncryptionInfogetEncryptionInfo()EncryptionModegetEncryptionMode()intgetFirstVisibleTab()sets the first tab that is displayed in the list of tabs in excel.HSSFFontgetFontAt(int idx)Get the font at the given index numberbooleangetForceFormulaRecalculation()Whether Excel will be asked to recalculate all formulas when the workbook is opened.InternalWorkbookgetInternalWorkbook()static intgetMaxImageLength()static intgetMaxRecordLength()Row.MissingCellPolicygetMissingCellPolicy()Retrieves the current policy on what to do when getting missing or blank cells from a row.HSSFNamegetName(String name)StringgetNameName(int index)gets the named range nameNameRecordgetNameRecord(int nameIndex)List<HSSFName>getNames(String name)Returns all defined names with the given name.intgetNumberOfFonts()Get the number of fonts in the font tableintgetNumberOfFontsAsInt()Deprecated.intgetNumberOfNames()intgetNumberOfSheets()get the number of spreadsheets in the workbook (this will be three after serialization)intgetNumCellStyles()get the number of styles the workbook containsStringgetPrintArea(int sheetIndex)Retrieves the reference for the printarea of the specified sheet, the sheet name is appended to the reference even if it was not specified.Collection<Integer>getSelectedTabs()Gets the selected sheets (if more than one, Excel calls these a [Group]).HSSFSheetgetSheet(String name)Get sheet with the given name (case insensitive match)HSSFSheetgetSheetAt(int index)Get the HSSFSheet object at the given index.intgetSheetIndex(String name)Returns the index of the sheet by his nameintgetSheetIndex(Sheet sheet)Returns the index of the given sheetStringgetSheetName(int sheetIndex)Get the sheet nameSheetVisibilitygetSheetVisibility(int sheetIx)Get the visibility (visible, hidden, very hidden) of a sheet in this workbookSpreadsheetVersiongetSpreadsheetVersion()Returns the spreadsheet version (EXCEL97) of this workbookInternalWorkbookgetWorkbook()static StringgetWorkbookDirEntryName(DirectoryNode directory)voidinsertChartRecord()Test only.booleanisHidden()booleanisSheetHidden(int sheetIx)Check whether a sheet is hidden.booleanisSheetVeryHidden(int sheetIx)Check whether a sheet is very hidden.booleanisWriteProtected()Is the workbook protected with a password (not encrypted)?intlinkExternalWorkbook(String name, Workbook workbook)Adds the LinkTable records required to allow formulas referencing the specified external workbook to be added to this one.voidremoveName(Name name)Remove a name.voidremovePrintArea(int sheetIndex)Delete the printarea for the sheet specifiedvoidremoveSheetAt(int index)Removes sheet at the given index.voidsetActiveSheet(int index)Convenience method to set the active sheet.voidsetBackupFlag(boolean backupValue)determine whether the Excel GUI will backup the workbook when saving.voidsetCellReferenceType(CellReferenceType cellReferenceType)Configure workbook to a specific cell reference type, e.g.voidsetEncryptionMode(EncryptionMode mode)Sets the encryption mode - if not set, defaults toEncryptionMode.cryptoAPI.voidsetFirstVisibleTab(int index)sets the first tab that is displayed in the list of tabs in excel.voidsetForceFormulaRecalculation(boolean value)Whether the application shall perform a full recalculation when the workbook is opened.voidsetHidden(boolean hiddenFlag)static voidsetMaxImageLength(int length)static voidsetMaxRecordLength(int length)voidsetMissingCellPolicy(Row.MissingCellPolicy missingCellPolicy)Sets the policy on what to do when getting missing or blank cells from a row.voidsetPrintArea(int sheetIndex, int startColumn, int endColumn, int startRow, int endRow)For the Convenience of Java Programmers maintaining pointers.voidsetPrintArea(int sheetIndex, String reference)Sets the printarea for the sheet providedvoidsetSelectedTab(int index)Selects a single sheet.voidsetSelectedTabs(int[] indexes)Selects multiple sheets as a group.voidsetSelectedTabs(Collection<Integer> indexes)Selects multiple sheets as a group.voidsetSheetHidden(int sheetIx, boolean hidden)Hide or unhide a sheet.voidsetSheetName(int sheetIx, String name)Set the sheet name.voidsetSheetOrder(String sheetname, int pos)sets the order of appearance for a given sheet.voidsetSheetVisibility(int sheetIx, SheetVisibility visibility)Hide or unhide a sheet.Iterator<Sheet>sheetIterator()Returns an iterator of the sheets in the workbook in sheet order.Spliterator<Sheet>spliterator()Returns a spliterator of the sheets in the workbook in sheet order.voidunwriteProtectWorkbook()removes the write protect flagvoidwrite()Write out this workbook to the currently openFilevia the writeablePOIFSFileSystemit was opened as.voidwrite(File newFile)Method write - write out this workbook to a newFile.voidwrite(OutputStream stream)Method write - write out this workbook to anOutputStream.voidwriteProtectWorkbook(String password, String username)protect a workbook with a password (not encrypted, just sets writeprotect flags and the password.- 
Methods inherited from class org.apache.poi.POIDocumentclearDirectory, createInformationProperties, getDirectory, getDocumentSummaryInformation, getEncryptedPropertyStreamName, getPropertySet, getPropertySet, getSummaryInformation, initDirectory, readProperties, readProperties, replaceDirectory, validateInPlaceWritePossible, writeProperties, writeProperties, writeProperties
 
- 
 
- 
- 
- 
Field Detail- 
INITIAL_CAPACITYpublic static final int INITIAL_CAPACITY used for compile-time performance/memory optimization. This determines the initial capacity for the sheet collection. Its currently set to 3. Changing it in this release will decrease performance since you're never allowed to have more or less than three sheets!
 
- 
 - 
Constructor Detail- 
HSSFWorkbookpublic HSSFWorkbook() Creates new HSSFWorkbook from scratch (start here!)
 - 
HSSFWorkbookpublic HSSFWorkbook(POIFSFileSystem fs) throws IOException Given a POI POIFSFileSystem object, read in its Workbook along with all related nodes, and populate the high and low level models.This calls HSSFWorkbook(POIFSFileSystem, boolean)with preserve nodes set to true.- Throws:
- IOException- if the stream cannot be read
- IllegalStateException- a number of runtime exceptions can be thrown, especially if there are problems with the input format
- See Also:
- HSSFWorkbook(POIFSFileSystem, boolean),- POIFSFileSystem
 
 - 
HSSFWorkbookpublic HSSFWorkbook(POIFSFileSystem fs, boolean preserveNodes) throws IOException Given a POI POIFSFileSystem object, read in its Workbook and populate the high and low level models. If you're reading in a workbook... start here!- Parameters:
- fs- the POI filesystem that contains the Workbook stream.
- preserveNodes- whether to preserve other nodes, such as macros. This takes more memory, so only say yes if you need to. If set, will store all of the POIFSFileSystem in memory
- Throws:
- IOException- if the stream cannot be read
- IllegalStateException- a number of runtime exceptions can be thrown, especially if there are problems with the input format
- See Also:
- POIFSFileSystem
 
 - 
HSSFWorkbookpublic HSSFWorkbook(DirectoryNode directory, POIFSFileSystem fs, boolean preserveNodes) throws IOException given a POI POIFSFileSystem object, and a specific directory within it, read in its Workbook and populate the high and low level models. If you're reading in a workbook...start here.- Parameters:
- directory- the POI filesystem directory to process from
- fs- the POI filesystem that contains the Workbook stream.
- preserveNodes- whether to preserve other nodes, such as macros. This takes more memory, so only say yes if you need to. If set, will store all of the POIFSFileSystem in memory
- Throws:
- IOException- if the stream cannot be read
- IllegalStateException- a number of runtime exceptions can be thrown, especially if there are problems with the input format
- See Also:
- POIFSFileSystem
 
 - 
HSSFWorkbookpublic HSSFWorkbook(DirectoryNode directory, boolean preserveNodes) throws IOException given a POI POIFSFileSystem object, and a specific directory within it, read in its Workbook and populate the high and low level models. If you're reading in a workbook...start here.- Parameters:
- directory- the POI filesystem directory to process from
- preserveNodes- whether to preserve other nodes, such as macros. This takes more memory, so only say yes if you need to. If set, will store all of the POIFSFileSystem in memory
- Throws:
- IOException- if the stream cannot be read
- IllegalStateException- a number of runtime exceptions can be thrown, especially if there are problems with the input format
- See Also:
- POIFSFileSystem
 
 - 
HSSFWorkbookpublic HSSFWorkbook(InputStream s) throws IOException Companion to HSSFWorkbook(POIFSFileSystem), this constructs the POI filesystem around yourInputStream, including all nodes.This calls HSSFWorkbook(InputStream, boolean)with preserve nodes set to true.- Throws:
- IOException- if the stream cannot be read
- IllegalStateException- a number of runtime exceptions can be thrown, especially if there are problems with the input format
- See Also:
- HSSFWorkbook(InputStream, boolean),- HSSFWorkbook(POIFSFileSystem),- POIFSFileSystem
 
 - 
HSSFWorkbookpublic HSSFWorkbook(InputStream s, boolean preserveNodes) throws IOException Companion to HSSFWorkbook(POIFSFileSystem), this constructs the POI filesystem around yourInputStream.- Parameters:
- s- the POI filesystem that contains the Workbook stream.
- preserveNodes- whether to preserve other nodes, such as macros. This takes more memory, so only say yes if you need to.
- Throws:
- IOException- if the stream cannot be read
- IllegalStateException- a number of runtime exceptions can be thrown, especially if there are problems with the input format
- See Also:
- POIFSFileSystem,- HSSFWorkbook(POIFSFileSystem)
 
 
- 
 - 
Method Detail- 
createpublic static HSSFWorkbook create(InternalWorkbook book) 
 - 
setMaxRecordLengthpublic static void setMaxRecordLength(int length) - Parameters:
- length- the max record length allowed for HSSFWorkbook
 
 - 
getMaxRecordLengthpublic static int getMaxRecordLength() - Returns:
- the max record length allowed for HSSFWorkbook
 
 - 
setMaxImageLengthpublic static void setMaxImageLength(int length) - Parameters:
- length- the max image length allowed for HSSFWorkbook
 
 - 
getMaxImageLengthpublic static int getMaxImageLength() - Returns:
- the max image length allowed for HSSFWorkbook
 
 - 
getWorkbookDirEntryNamepublic static String getWorkbookDirEntryName(DirectoryNode directory) 
 - 
getMissingCellPolicypublic Row.MissingCellPolicy getMissingCellPolicy() Retrieves the current policy on what to do when getting missing or blank cells from a row. The default is to return blank and null cells.Row.MissingCellPolicy- Specified by:
- getMissingCellPolicyin interface- Workbook
 
 - 
setMissingCellPolicypublic void setMissingCellPolicy(Row.MissingCellPolicy missingCellPolicy) Sets the policy on what to do when getting missing or blank cells from a row. This will then apply to all calls toHSSFRow.getCell(int)}. SeeRow.MissingCellPolicy. Note that this has no effect on any iterators, only on when fetching Cells by their column index.- Specified by:
- setMissingCellPolicyin interface- Workbook
 
 - 
setSheetOrderpublic void setSheetOrder(String sheetname, int pos) sets the order of appearance for a given sheet.- Specified by:
- setSheetOrderin interface- Workbook
- Parameters:
- sheetname- the name of the sheet to reorder
- pos- the position that we want to insert the sheet into (0 based)
 
 - 
setSelectedTabpublic void setSelectedTab(int index) Selects a single sheet. This may be different to the 'active' sheet (which is the sheet with focus).- Specified by:
- setSelectedTabin interface- Workbook
- Parameters:
- index- the index of the sheet to select (0 based)
- See Also:
- Sheet.setSelected(boolean)
 
 - 
setSelectedTabspublic void setSelectedTabs(int[] indexes) Selects multiple sheets as a group. This is distinct from the 'active' sheet (which is the sheet with focus). Unselects sheets that are not inindexes.- Parameters:
- indexes- Array of sheets to select, the index is 0-based.
 
 - 
setSelectedTabspublic void setSelectedTabs(Collection<Integer> indexes) Selects multiple sheets as a group. This is distinct from the 'active' sheet (which is the sheet with focus). Unselects sheets that are not inindexes.- Parameters:
- indexes- Collection of sheets to select, the index is 0-based.
 
 - 
getSelectedTabspublic Collection<Integer> getSelectedTabs() Gets the selected sheets (if more than one, Excel calls these a [Group]).- Returns:
- indices of selected sheets
 
 - 
setActiveSheetpublic void setActiveSheet(int index) Convenience method to set the active sheet. The active sheet is is the sheet which is currently displayed when the workbook is viewed in Excel. 'Selected' sheet(s) is a distinct concept.- Specified by:
- setActiveSheetin interface- Workbook
- Parameters:
- index- index of the active sheet (0-based)
 
 - 
getActiveSheetIndexpublic int getActiveSheetIndex() gets the tab whose data is actually seen when the sheet is opened. This may be different from the "selected sheet" since excel seems to allow you to show the data of one sheet when another is seen "selected" in the tabs (at the bottom).- Specified by:
- getActiveSheetIndexin interface- Workbook
- Returns:
- the index of the active sheet (0-based)
- See Also:
- HSSFSheet.setSelected(boolean)
 
 - 
setFirstVisibleTabpublic void setFirstVisibleTab(int index) sets the first tab that is displayed in the list of tabs in excel. This method does not hide, select or focus sheets. It just sets the scroll position in the tab-bar.- Specified by:
- setFirstVisibleTabin interface- Workbook
- Parameters:
- index- the sheet index of the tab that will become the first in the tab-bar
 
 - 
getFirstVisibleTabpublic int getFirstVisibleTab() sets the first tab that is displayed in the list of tabs in excel.- Specified by:
- getFirstVisibleTabin interface- Workbook
- Returns:
- the first tab that to display in the list of tabs (0-based).
 
 - 
setSheetNamepublic void setSheetName(int sheetIx, String name)Set the sheet name.- Specified by:
- setSheetNamein interface- Workbook
- Parameters:
- sheetIx- number (0 based)
- Throws:
- IllegalArgumentException- if the name is null or invalid or workbook already contains a sheet with this name
- See Also:
- createSheet(String),- WorkbookUtil.createSafeSheetName(String nameProposal)
 
 - 
getSheetNamepublic String getSheetName(int sheetIndex) Description copied from interface:WorkbookGet the sheet name- Specified by:
- getSheetNamein interface- Workbook
- Parameters:
- sheetIndex- sheet number (0 based)
- Returns:
- Sheet name for the specified index
 
 - 
isHiddenpublic boolean isHidden() 
 - 
setHiddenpublic void setHidden(boolean hiddenFlag) 
 - 
isSheetHiddenpublic boolean isSheetHidden(int sheetIx) Description copied from interface:WorkbookCheck whether a sheet is hidden.Note that a sheet could instead be set to be very hidden, which is different ( Workbook.isSheetVeryHidden(int))- Specified by:
- isSheetHiddenin interface- Workbook
- Parameters:
- sheetIx- Number
- Returns:
- trueif sheet is hidden
- See Also:
- Workbook.getSheetVisibility(int)
 
 - 
isSheetVeryHiddenpublic boolean isSheetVeryHidden(int sheetIx) Description copied from interface:WorkbookCheck whether a sheet is very hidden.This is different from the normal hidden status ( Workbook.isSheetHidden(int))- Specified by:
- isSheetVeryHiddenin interface- Workbook
- Parameters:
- sheetIx- sheet index to check
- Returns:
- trueif sheet is very hidden
- See Also:
- Workbook.getSheetVisibility(int)
 
 - 
getSheetVisibilitypublic SheetVisibility getSheetVisibility(int sheetIx) Description copied from interface:WorkbookGet the visibility (visible, hidden, very hidden) of a sheet in this workbook- Specified by:
- getSheetVisibilityin interface- Workbook
- Parameters:
- sheetIx- the index of the sheet
- Returns:
- the sheet visibility
 
 - 
setSheetHiddenpublic void setSheetHidden(int sheetIx, boolean hidden)Description copied from interface:WorkbookHide or unhide a sheet. Please note that the sheet currently set as active sheet (sheet 0 in a newly created workbook or the one set via setActiveSheet()) cannot be hidden.- Specified by:
- setSheetHiddenin interface- Workbook
- Parameters:
- sheetIx- the sheet index (0-based)
- hidden- True to mark the sheet as hidden, false otherwise
- See Also:
- Workbook.setSheetVisibility(int, SheetVisibility)
 
 - 
setSheetVisibilitypublic void setSheetVisibility(int sheetIx, SheetVisibility visibility)Description copied from interface:WorkbookHide or unhide a sheet. Please note that the sheet currently set as active sheet (sheet 0 in a newly created workbook or the one set via setActiveSheet()) cannot be hidden.- Specified by:
- setSheetVisibilityin interface- Workbook
- Parameters:
- sheetIx- the sheet index (0-based)
- visibility- the sheet visibility to set
 
 - 
getSheetIndexpublic int getSheetIndex(String name) Returns the index of the sheet by his name- Specified by:
- getSheetIndexin interface- Workbook
- Parameters:
- name- the sheet name
- Returns:
- index of the sheet (0 based) or -1 if it was not found.
 
 - 
getSheetIndexpublic int getSheetIndex(Sheet sheet) Returns the index of the given sheet- Specified by:
- getSheetIndexin interface- Workbook
- Parameters:
- sheet- the sheet to look up
- Returns:
- index of the sheet (0 based). -1if not found
 
 - 
createSheetpublic HSSFSheet createSheet() create an HSSFSheet for this HSSFWorkbook, adds it to the sheets and returns the high level representation. Use this to create new sheets.- Specified by:
- createSheetin interface- Workbook
- Returns:
- HSSFSheet representing the new sheet.
 
 - 
cloneSheetpublic HSSFSheet cloneSheet(int sheetIndex) create an HSSFSheet from an existing sheet in the HSSFWorkbook.- Specified by:
- cloneSheetin interface- Workbook
- Returns:
- HSSFSheet representing the cloned sheet.
 
 - 
createSheetpublic HSSFSheet createSheet(String sheetname) Create a new sheet for this Workbook and return the high level representation. Use this to create new sheets.Note that Excel allows sheet names up to 31 chars in length but other applications (such as OpenOffice) allow more. Some versions of Excel crash with names longer than 31 chars, others - truncate such names to 31 character. POI's SpreadsheetAPI silently truncates the input argument to 31 characters. Example: Sheet sheet = workbook.createSheet("My very long sheet name which is longer than 31 chars"); // will be truncated assert 31 == sheet.getSheetName().length(); assert "My very long sheet name which i" == sheet.getSheetName();Except the 31-character constraint, Excel applies some other rules: Sheet name MUST be unique in the workbook and MUST NOT contain the any of the following characters: - 0x0000
- 0x0003
- colon (:)
- backslash (\)
- asterisk (*)
- question mark (?)
- forward slash (/)
- opening square bracket ([)
- closing square bracket (])
 - Specified by:
- createSheetin interface- Workbook
- Parameters:
- sheetname- sheetname to set for the sheet.
- Returns:
- Sheet representing the new sheet.
- Throws:
- IllegalArgumentException- if the name is null or invalid or workbook already contains a sheet with this name
- See Also:
- WorkbookUtil.createSafeSheetName(String nameProposal)
 
 - 
sheetIteratorpublic Iterator<Sheet> sheetIterator() Returns an iterator of the sheets in the workbook in sheet order. Includes hidden and very hidden sheets.- Specified by:
- sheetIteratorin interface- Workbook
- Returns:
- an iterator of the sheets.
 
 - 
spliteratorpublic Spliterator<Sheet> spliterator() Returns a spliterator of the sheets in the workbook in sheet order. Includes hidden and very hidden sheets.- Specified by:
- spliteratorin interface- Iterable<Sheet>
- Specified by:
- spliteratorin interface- Workbook
- Returns:
- a spliterator of the sheets.
- Since:
- POI 5.2.0
 
 - 
getNumberOfSheetspublic int getNumberOfSheets() get the number of spreadsheets in the workbook (this will be three after serialization)- Specified by:
- getNumberOfSheetsin interface- Workbook
- Returns:
- number of sheets
 
 - 
getSheetAtpublic HSSFSheet getSheetAt(int index) Get the HSSFSheet object at the given index.- Specified by:
- getSheetAtin interface- Workbook
- Parameters:
- index- of the sheet number (0-based physical & logical)
- Returns:
- HSSFSheet at the provided index
- Throws:
- IllegalArgumentException- if the index is out of range (index < 0 || index >= getNumberOfSheets()).
 
 - 
getSheetpublic HSSFSheet getSheet(String name) Get sheet with the given name (case insensitive match)
 - 
removeSheetAtpublic void removeSheetAt(int index) Removes sheet at the given index.Care must be taken if the removed sheet is the currently active or only selected sheet in the workbook. There are a few situations when Excel must have a selection and/or active sheet. (For example when printing - see Bug 40414). 
 This method makes sure that if the removed sheet was active, another sheet will become active in its place. Furthermore, if the removed sheet was the only selected sheet, another sheet will become selected. The newly active/selected sheet will have the same index, or one less if the removed sheet was the last in the workbook. - Specified by:
- removeSheetAtin interface- Workbook
- Parameters:
- index- of the sheet (0-based)
 
 - 
setBackupFlagpublic void setBackupFlag(boolean backupValue) determine whether the Excel GUI will backup the workbook when saving.- Parameters:
- backupValue- true to indicate a backup will be performed.
 
 - 
getBackupFlagpublic boolean getBackupFlag() determine whether the Excel GUI will backup the workbook when saving.- Returns:
- the current setting for backups.
 
 - 
createFontpublic HSSFFont createFont() create a new Font and add it to the workbook's font table- Specified by:
- createFontin interface- Workbook
- Returns:
- new font object
 
 - 
findFontpublic HSSFFont findFont(boolean bold, short color, short fontHeight, String name, boolean italic, boolean strikeout, short typeOffset, byte underline) Finds a font that matches the one with the supplied attributes
 - 
getNumberOfFontspublic int getNumberOfFonts() Description copied from interface:WorkbookGet the number of fonts in the font table- Specified by:
- getNumberOfFontsin interface- Workbook
- Returns:
- number of fonts (as int since POI 5.0.0)
 
 - 
getNumberOfFontsAsInt@Deprecated @Removal(version="6.0.0") public int getNumberOfFontsAsInt() Deprecated.Description copied from interface:WorkbookGet the number of fonts in the font table- Specified by:
- getNumberOfFontsAsIntin interface- Workbook
- Returns:
- number of fonts
 
 - 
getFontAtpublic HSSFFont getFontAt(int idx) Description copied from interface:WorkbookGet the font at the given index number
 - 
createCellStylepublic HSSFCellStyle createCellStyle() Create a new Cell style and add it to the workbook's style table. You can define up to 4000 unique styles in a .xls workbook.- Specified by:
- createCellStylein interface- Workbook
- Returns:
- the new Cell Style object
- Throws:
- IllegalStateException- if the number of cell styles exceeded the limit for this type of Workbook.
 
 - 
getNumCellStylespublic int getNumCellStyles() get the number of styles the workbook contains- Specified by:
- getNumCellStylesin interface- Workbook
- Returns:
- count of cell styles
 
 - 
getCellStyleAtpublic HSSFCellStyle getCellStyleAt(int idx) get the cell style object at the given index- Specified by:
- getCellStyleAtin interface- Workbook
- Parameters:
- idx- index within the set of styles
- Returns:
- HSSFCellStyle object at the index
 
 - 
closepublic void close() throws IOExceptionCloses the underlyingPOIFSFileSystemfrom which the Workbook was read, if any.Once this has been called, no further operations, updates or reads should be performed on the Workbook. - Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- Closeable
- Specified by:
- closein interface- Workbook
- Overrides:
- closein class- POIDocument
- Throws:
- IOException
 
 - 
writepublic void write() throws IOExceptionWrite out this workbook to the currently openFilevia the writeablePOIFSFileSystemit was opened as.This will fail (with an IllegalStateExceptionif the Workbook was opened read-only, opened from anInputStreaminstead of a File, or if this is not the root document. For those cases, you must usewrite(OutputStream)orwrite(File)to write to a brand new document.- Specified by:
- writein class- POIDocument
- Throws:
- IOException- thrown on errors writing to the file
 
 - 
writepublic void write(File newFile) throws IOException Method write - write out this workbook to a newFile. Constructs a new POI POIFSFileSystem, passes in the workbook binary representation and writes it out. If the file exists, it will be replaced, otherwise a new one will be created.Note that you cannot write to the currently open File using this method. If you opened your Workbook from a File, you must use the write()method instead!- Specified by:
- writein class- POIDocument
- Parameters:
- newFile- The new File you wish to write the XLS to
- Throws:
- IOException- if anything can't be written.
- See Also:
- POIFSFileSystem
 
 - 
writepublic void write(OutputStream stream) throws IOException Method write - write out this workbook to anOutputStream. Constructs a new POI POIFSFileSystem, passes in the workbook binary representation and writes it out.If streamis aFileOutputStreamon a networked drive or has a high cost/latency associated with each written byte, consider wrapping the OutputStream in aBufferedOutputStreamto improve write performance.- Specified by:
- writein interface- Workbook
- Specified by:
- writein class- POIDocument
- Parameters:
- stream- - the java OutputStream you wish to write the XLS to
- Throws:
- IOException- if anything can't be written.
- See Also:
- POIFSFileSystem
 
 - 
getBytespublic byte[] getBytes() Method getBytes - get the bytes of just the HSSF portions of the XLS file. Use this to construct a POI POIFSFileSystem yourself.- Returns:
- byte[] array containing the binary representation of this workbook and all contained sheets, rows, cells, etc.
 
 - 
getWorkbook@Internal public InternalWorkbook getWorkbook() 
 - 
getNumberOfNamespublic int getNumberOfNames() - Specified by:
- getNumberOfNamesin interface- Workbook
- Returns:
- the total number of defined names in this workbook
 
 - 
getNamespublic List<HSSFName> getNames(String name) Description copied from interface:WorkbookReturns all defined names with the given name.
 - 
getAllNamespublic List<HSSFName> getAllNames() Description copied from interface:WorkbookReturns all defined names.- Specified by:
- getAllNamesin interface- Workbook
- Returns:
- a list of the defined names. An empty list is returned if none is found.
 
 - 
getNameRecordpublic NameRecord getNameRecord(int nameIndex) 
 - 
getNameNamepublic String getNameName(int index) gets the named range name- Parameters:
- index- the named range index (0 based)
- Returns:
- named range name
 
 - 
setPrintAreapublic void setPrintArea(int sheetIndex, String reference)Sets the printarea for the sheet providedi.e. Reference = $A$1:$B$2 - Specified by:
- setPrintAreain interface- Workbook
- Parameters:
- sheetIndex- Zero-based sheet index (0 Represents the first sheet to keep consistent with java)
- reference- Valid name Reference for the Print Area
 
 - 
setPrintAreapublic void setPrintArea(int sheetIndex, int startColumn, int endColumn, int startRow, int endRow)For the Convenience of Java Programmers maintaining pointers.- Specified by:
- setPrintAreain interface- Workbook
- Parameters:
- sheetIndex- Zero-based sheet index (0 = First Sheet)
- startColumn- Column to begin printarea
- endColumn- Column to end the printarea
- startRow- Row to begin the printarea
- endRow- Row to end the printarea
- See Also:
- setPrintArea(int, String)
 
 - 
getPrintAreapublic String getPrintArea(int sheetIndex) Retrieves the reference for the printarea of the specified sheet, the sheet name is appended to the reference even if it was not specified.- Specified by:
- getPrintAreain interface- Workbook
- Parameters:
- sheetIndex- Zero-based sheet index (0 Represents the first sheet to keep consistent with java)
- Returns:
- String Null if no print area has been defined
 
 - 
removePrintAreapublic void removePrintArea(int sheetIndex) Delete the printarea for the sheet specified- Specified by:
- removePrintAreain interface- Workbook
- Parameters:
- sheetIndex- Zero-based sheet index (0 = First Sheet)
 
 - 
createNamepublic HSSFName createName() creates a new named range and add it to the model- Specified by:
- createNamein interface- Workbook
- Returns:
- named range high level
 
 - 
getCellReferenceTypepublic CellReferenceType getCellReferenceType() - Specified by:
- getCellReferenceTypein interface- Workbook
- Returns:
- the type of cell references used
 
 - 
setCellReferenceTypepublic void setCellReferenceType(CellReferenceType cellReferenceType) Configure workbook to a specific cell reference type, e.g. R1C1 cell references (as opposed to A1 cell references).Note that HSSF format stores this information at sheet level - so if the workbook has no sheets, this call will have no effect. It is recommended that you call this (possibly again) just before writing HSSFWorkbook. - Specified by:
- setCellReferenceTypein interface- Workbook
- Parameters:
- cellReferenceType- the type of cell references used
- Since:
- POI 5.2.1
 
 - 
createDataFormatpublic HSSFDataFormat createDataFormat() Returns the instance of HSSFDataFormat for this workbook.- Specified by:
- createDataFormatin interface- Workbook
- Returns:
- the HSSFDataFormat object
- See Also:
- FormatRecord,- Record
 
 - 
removeNamepublic void removeName(Name name) Remove a name.- Specified by:
- removeNamein interface- Workbook
- Parameters:
- name- the name to remove.
 
 - 
getCustomPalettepublic HSSFPalette getCustomPalette() 
 - 
insertChartRecordpublic void insertChartRecord() Test only. Do not use
 - 
dumpDrawingGroupRecordspublic void dumpDrawingGroupRecords(boolean fat) Spits out a list of all the drawing records in the workbook.
 - 
addPicturepublic int addPicture(byte[] pictureData, int format)Adds a picture to the workbook.- Specified by:
- addPicturein interface- Workbook
- Parameters:
- pictureData- The bytes of the picture
- format- The format of the picture. One of- PICTURE_TYPE_*
- Returns:
- the index to this picture (1 based).
- See Also:
- Workbook.PICTURE_TYPE_WMF,- Workbook.PICTURE_TYPE_EMF,- Workbook.PICTURE_TYPE_PICT,- Workbook.PICTURE_TYPE_PNG,- Workbook.PICTURE_TYPE_JPEG,- Workbook.PICTURE_TYPE_DIB
 
 - 
getAllPicturespublic List<HSSFPictureData> getAllPictures() Gets all pictures from the Workbook.- Specified by:
- getAllPicturesin interface- Workbook
- Returns:
- the list of pictures (a list of HSSFPictureDataobjects.)
 
 - 
addOlePackagepublic int addOlePackage(POIFSFileSystem poiData, String label, String fileName, String command) throws IOException Adds an OLE package manager object with the given POIFS to the sheet- Parameters:
- poiData- an POIFS containing the embedded document, to be added
- label- the label of the payload
- fileName- the original filename
- command- the command to open the payload
- Returns:
- the index of the added ole object
- Throws:
- IOException- if the object can't be embedded
 
 - 
addOlePackagepublic int addOlePackage(byte[] oleData, String label, String fileName, String command) throws IOExceptionDescription copied from interface:WorkbookAdds an OLE package manager object with the given content to the sheet- Specified by:
- addOlePackagein interface- Workbook
- Parameters:
- oleData- the payload
- label- the label of the payload
- fileName- the original filename
- command- the command to open the payload
- Returns:
- the index of the added ole object, i.e. the storage id
- Throws:
- IOException- if the object can't be embedded
 
 - 
linkExternalWorkbookpublic int linkExternalWorkbook(String name, Workbook workbook) Adds the LinkTable records required to allow formulas referencing the specified external workbook to be added to this one. Allows formulas such as "[MyOtherWorkbook]Sheet3!$A$5" to be added to the file, for workbooks not already referenced.- Specified by:
- linkExternalWorkbookin interface- Workbook
- Parameters:
- name- The name the workbook will be referenced as in formulas
- workbook- The open workbook to fetch the link required information from
 
 - 
isWriteProtectedpublic boolean isWriteProtected() Is the workbook protected with a password (not encrypted)?
 - 
writeProtectWorkbookpublic void writeProtectWorkbook(String password, String username) protect a workbook with a password (not encrypted, just sets writeprotect flags and the password.- Parameters:
- password- to set
 
 - 
unwriteProtectWorkbookpublic void unwriteProtectWorkbook() removes the write protect flag
 - 
getAllEmbeddedObjectspublic List<HSSFObjectData> getAllEmbeddedObjects() Gets all embedded OLE2 objects from the Workbook.- Returns:
- the list of embedded objects (a list of HSSFObjectDataobjects.)
 
 - 
getCreationHelperpublic HSSFCreationHelper getCreationHelper() Description copied from interface:WorkbookReturns an object that handles instantiating concrete classes of the various instances one needs for HSSF and XSSF.- Specified by:
- getCreationHelperin interface- Workbook
 
 - 
addToolPackpublic void addToolPack(UDFFinder toolpack) Register a new toolpack in this workbook.- Specified by:
- addToolPackin interface- Workbook
- Parameters:
- toolpack- the toolpack to register
 
 - 
setForceFormulaRecalculationpublic void setForceFormulaRecalculation(boolean value) Whether the application shall perform a full recalculation when the workbook is opened.Typically you want to force formula recalculation when you modify cell formulas or values of a workbook previously created by Excel. When set to true, this flag will tell Excel that it needs to recalculate all formulas in the workbook the next time the file is opened. Note, that recalculation updates cached formula results and, thus, modifies the workbook. Depending on the version, Excel may prompt you with "Do you want to save the changes in filename?" on close. - Specified by:
- setForceFormulaRecalculationin interface- Workbook
- Parameters:
- value- true if the application will perform a full recalculation of workbook values when the workbook is opened
- Since:
- 3.8
 
 - 
getForceFormulaRecalculationpublic boolean getForceFormulaRecalculation() Whether Excel will be asked to recalculate all formulas when the workbook is opened.- Specified by:
- getForceFormulaRecalculationin interface- Workbook
- Since:
- 3.8
 
 - 
changeExternalReferencepublic boolean changeExternalReference(String oldUrl, String newUrl) Changes an external referenced file to another file. A formula in Excel which references a cell in another file is saved in two parts: The referenced file is stored in an reference table. the row/cell information is saved separate. This method invocation will only change the reference in the lookup-table itself.- Parameters:
- oldUrl- The old URL to search for and which is to be replaced
- newUrl- The URL replacement
- Returns:
- true if the oldUrl was found and replaced with newUrl. Otherwise false
 
 - 
getInternalWorkbook@Internal public InternalWorkbook getInternalWorkbook() 
 - 
getSpreadsheetVersionpublic SpreadsheetVersion getSpreadsheetVersion() Returns the spreadsheet version (EXCEL97) of this workbook- Specified by:
- getSpreadsheetVersionin interface- Workbook
- Returns:
- EXCEL97 SpreadsheetVersion enum
- Since:
- 3.14 beta 2
 
 - 
getEncryptionInfopublic EncryptionInfo getEncryptionInfo() - Overrides:
- getEncryptionInfoin class- POIDocument
- Returns:
- the encryption info if the document is encrypted, otherwise null
 
 - 
createEvaluationWorkbookpublic HSSFEvaluationWorkbook createEvaluationWorkbook() - Specified by:
- createEvaluationWorkbookin interface- Workbook
- Returns:
- an evaluation workbook
 
 - 
setEncryptionModepublic void setEncryptionMode(EncryptionMode mode) Sets the encryption mode - if not set, defaults toEncryptionMode.cryptoAPI. Allowed modes arenull= remove encryption - same asBiff8EncryptionKey.setCurrentUserPassword(null),EncryptionMode.cryptoAPI,EncryptionMode.binaryRC4,EncryptionMode.xor. UseEncryptionMode.binaryRC4for Libre Office, but better use OOXML format/encryption for real security.- Parameters:
- mode- the encryption mode
 
 - 
getEncryptionModepublic EncryptionMode getEncryptionMode() - Returns:
- the encryption mode or nullif unset
 
 
- 
 
-