|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object | +--org.apache.poi.hssf.model.Workbook
Workbook Low level model implementation of a Workbook. Provides creational methods for settings and objects contained in the workbook object.
This file contains the low level binary records starting at the workbook's BOF and ending with the workbook's EOF. Use HSSFWorkbook for a high level representation.
The structures of the highlevel API use references to this to perform most of their operations. Its probably unwise to use these low level structures directly unless you really know what you're doing. I recommend you read the Microsoft Excel 97 Developer's Kit (Microsoft Press) and the documentation at http://sc.openoffice.org/excelfileformat.pdf before even attempting to use this.
HSSFWorkbook
Field Summary | |
protected java.util.ArrayList |
boundsheets
holds the "boundsheet" records (aka bundlesheet) so that they can have their reference to their "BOF" marker |
protected int |
bspos
|
protected int |
fontpos
|
protected int |
numfonts
|
protected int |
numxfs
|
protected java.util.ArrayList |
records
this contains the Worksheet record objects |
protected SSTRecord |
sst
this contains a reference to the SSTRecord so that new stings can be added to it. |
protected int |
tabpos
|
protected int |
xfpos
|
Constructor Summary | |
Workbook()
Creates new Workbook with no intitialization --useless right now |
Method Summary | |
int |
addSSTString(java.lang.String string)
Adds a string to the SST table and returns its index (if its a duplicate just returns its index and update the counts) ASSUMES compressed unicode (meaning 8bit) |
int |
addSSTString(java.lang.String string,
boolean use16bits)
Adds a string to the SST table and returns its index (if its a duplicate just returns its index and update the counts) |
protected Record |
createBackup()
creates the Backup record with backup set to 0. |
protected Record |
createBOF()
creates the BOF record |
protected Record |
createBookBool()
creates the BookBool record with saveLinkValues set to 0. |
protected Record |
createBoundSheet(int id)
create a "bound sheet" or "bundlesheet" (depending who you ask) record Always sets the sheet's bof to 0. |
ExtendedFormatRecord |
createCellXF()
creates a new Cell-type Extneded Format Record and adds it to the end of ExtendedFormatRecords collection |
protected Record |
createCodepage()
creates the Codepage record containing the constant stored in CODEPAGE |
protected Record |
createCountry()
Creates the Country record with the default and current country set to 1 |
protected Record |
createDateWindow1904()
creates the DateWindow1904 record with windowing set to 0. |
protected Record |
createDSF()
creates the DSF record containing a 0 since HSSF can't even create Dual Stream Files |
protected Record |
createEOF()
creates the EOF record |
protected ExtendedFormatRecord |
createExtendedFormat()
creates an default cell type ExtendedFormatRecord object. |
protected Record |
createExtendedFormat(int id)
Creates an ExtendedFormatRecord object |
protected Record |
createExtendedSST()
Creates the ExtendedSST record with numstrings per bucket set to 0x8. |
protected Record |
createFnGroupCount()
creates the FnGroupCount record containing the Magic number constant of 14. |
protected Record |
createFont()
creates a Font record with the following magic values: |
protected Record |
createFormat(int id)
Creates a FormatRecord object |
protected Record |
createHideObj()
creates the HideObj record with hide object set to 0. |
protected Record |
createInterfaceEnd()
creates the InterfaceEnd record |
protected Record |
createInterfaceHdr()
creates the InterfaceHdr record |
protected Record |
createMMS()
creates an MMS record |
FontRecord |
createNewFont()
creates a new font record and adds it to the "font table". |
protected Record |
createPassword()
creates the Password record with password set to 0. |
protected Record |
createPasswordRev4()
creates the PasswordRev4 record with password set to 0. |
protected Record |
createPrecision()
creates the Precision record with precision set to true. |
protected Record |
createProtect()
creates the Protect record with protect set to false. |
protected Record |
createProtectionRev4()
creates the ProtectionRev4 record with protect set to false. |
protected Record |
createRefreshAll()
creates the RefreshAll record with refreshAll set to true. |
protected Record |
createSST()
Creates the SST record with no strings and the unique/num string set to 0 |
protected Record |
createStyle(int id)
Creates a StyleRecord object |
protected Record |
createTabId()
creates the TabId record containing an array of 0,1,2. |
protected Record |
createUseSelFS()
Creates the UseSelFS object with the use natural language flag set to 0 (false) |
protected Record |
createWindowOne()
creates the WindowOne record with the following magic values: |
protected Record |
createWindowProtect()
creates the WindowProtect record with protect set to false. |
static Workbook |
createWorkbook()
Creates an empty workbook object with three blank sheets and all the empty fields. |
static Workbook |
createWorkbook(java.util.List recs)
read support for low level API. |
protected Record |
createWriteAccess()
creates the WriteAccess record containing the logged in user's name |
Record |
findFirstRecordBySid(short sid)
Returns the first occurance of a record matching a particular sid. |
BackupRecord |
getBackupRecord()
Returns the position of the backup record. |
ExtendedFormatRecord |
getExFormatAt(int index)
gets the ExtendedFormatRecord at the given 0-based index |
FontRecord |
getFontRecordAt(int idx)
gets the font record at the given index in the font table. |
int |
getNumberOfFontRecords()
gets the number of font records |
int |
getNumExFormats()
get the number of ExtendedFormat records contained in this workbook. |
int |
getNumRecords()
|
int |
getNumSheets()
returns the number of boundsheet objects contained in this workbook. |
java.lang.String |
getSheetName(int sheetnum)
gets the name for a given sheet. |
int |
getSize()
|
java.lang.String |
getSSTString(int str)
given an index into the SST table, this function returns the corresponding String value |
void |
insertSST()
use this function to add a Shared String Table to an existing sheet (say generated by a different java api) without an sst.... |
void |
removeSheet(int sheetnum)
|
byte[] |
serialize()
Serializes all records int the worksheet section into a big byte array. |
int |
serialize(int offset,
byte[] data)
Serializes all records int the worksheet section into a big byte array. |
void |
setSheetBof(int sheetnum,
int pos)
Sets the BOF for a given sheet |
void |
setSheetName(int sheetnum,
java.lang.String sheetname)
sets the name for a given sheet. |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
protected java.util.ArrayList records
protected SSTRecord sst
protected java.util.ArrayList boundsheets
protected int bspos
protected int tabpos
protected int fontpos
protected int numfonts
protected int xfpos
protected int numxfs
Constructor Detail |
public Workbook()
createWorkbook(List)
Method Detail |
public static Workbook createWorkbook(java.util.List recs)
recs
- an array of Record objectspublic static Workbook createWorkbook()
public int getNumRecords()
public FontRecord getFontRecordAt(int idx)
idx
- the index to look at (0 or greater but NOT 4)public FontRecord createNewFont()
public int getNumberOfFontRecords()
public void setSheetBof(int sheetnum, int pos)
sheetnum
- the number of the sheet to set the positing of the bof forpos
- the actual bof positionpublic BackupRecord getBackupRecord()
public void setSheetName(int sheetnum, java.lang.String sheetname)
sheetnum
- the sheet number (0 based)sheetname
- the name for the sheetpublic java.lang.String getSheetName(int sheetnum)
sheetnum
- the sheet number (0 based)public void removeSheet(int sheetnum)
public int getNumSheets()
public int getNumExFormats()
public ExtendedFormatRecord getExFormatAt(int index)
index
- of the Extended format record (0-based)public ExtendedFormatRecord createCellXF()
public int addSSTString(java.lang.String string, boolean use16bits)
string
- the string to be added to the SSTRecorduse16bits
- whether to use utf 16 or false for compressed unicodepublic int addSSTString(java.lang.String string)
string
- the string to be added to the SSTRecordpublic java.lang.String getSSTString(int str)
public void insertSST()
createSST()
,
SSTRecord
public byte[] serialize()
public int serialize(int offset, byte[] data)
offset
- of the data to be writtendata
- array of bytes to write this topublic int getSize()
protected Record createBOF()
BOFRecord
,
Record
protected Record createInterfaceHdr()
InterfaceHdrRecord
,
Record
protected Record createMMS()
MMSRecord
,
Record
protected Record createInterfaceEnd()
InterfaceEndRecord
,
Record
protected Record createWriteAccess()
WriteAccessRecord
,
Record
protected Record createCodepage()
CodepageRecord
,
Record
protected Record createDSF()
DSFRecord
,
Record
protected Record createTabId()
TabIdRecord
,
Record
protected Record createFnGroupCount()
FnGroupCountRecord
,
Record
protected Record createWindowProtect()
WindowProtectRecord
,
Record
protected Record createProtect()
ProtectRecord
,
Record
protected Record createPassword()
PasswordRecord
,
Record
protected Record createProtectionRev4()
ProtectionRev4Record
,
Record
protected Record createPasswordRev4()
PasswordRev4Record
,
Record
protected Record createWindowOne()
horizontal hold - 0x168
vertical hold - 0x10e
width - 0x3a5c
height - 0x23be
options - 0x38
selected tab - 0
displayed tab - 0
num selected tab- 0
tab width ratio - 0x258
WindowOneRecord
,
Record
protected Record createBackup()
BackupRecord
,
Record
protected Record createHideObj()
HideObjRecord
,
Record
protected Record createDateWindow1904()
DateWindow1904Record
,
Record
protected Record createPrecision()
PrecisionRecord
,
Record
protected Record createRefreshAll()
RefreshAllRecord
,
Record
protected Record createBookBool()
BookBoolRecord
,
Record
protected Record createFont()
fontheight = 0xc8
attributes = 0x0
color palette index = 0x7fff
bold weight = 0x190
Font Name Length = 5
Font Name = Arial
FontRecord
,
Record
protected Record createFormat(int id)
id
- the number of the format record to create (meaning its position in
a file as M$ Excel would create it.)FormatRecord
,
Record
protected Record createExtendedFormat(int id)
id
- the number of the extended format record to create (meaning its position in
a file as MS Excel would create it.)ExtendedFormatRecord
,
Record
protected ExtendedFormatRecord createExtendedFormat()
protected Record createStyle(int id)
id
- the number of the style record to create (meaning its position in
a file as MS Excel would create it.StyleRecord
,
Record
protected Record createUseSelFS()
UseSelFSRecord
,
Record
protected Record createBoundSheet(int id)
id
- either sheet 0,1 or 2.BoundSheetRecord
,
Record
protected Record createCountry()
CountryRecord
,
Record
protected Record createSST()
SSTRecord
,
Record
protected Record createExtendedSST()
ExtSSTRecord
,
Record
protected Record createEOF()
EOFRecord
,
Record
public Record findFirstRecordBySid(short sid)
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: INNER | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |