Package org.apache.poi.hssf.usermodel
Class HSSFRow
- java.lang.Object
-
- org.apache.poi.hssf.usermodel.HSSFRow
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.apache.poi.ss.usermodel.Row
Row.MissingCellPolicy
-
-
Field Summary
Fields Modifier and Type Field Description static intINITIAL_CAPACITY
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description java.util.Iterator<Cell>cellIterator()intcompareTo(HSSFRow other)Compares twoHSSFRowobjects.HSSFCellcreateCell(int column)Use this to create new cells within the row and return it.HSSFCellcreateCell(int columnIndex, CellType type)Use this to create new cells within the row and return it.booleanequals(java.lang.Object obj)HSSFCellgetCell(int cellnum)Get the hssfcell representing a given column (logical cell) 0-based.HSSFCellgetCell(int cellnum, Row.MissingCellPolicy policy)Get the hssfcell representing a given column (logical cell) 0-based.shortgetFirstCellNum()get the number of the first cell contained in this row.shortgetHeight()get the row's height or ff (-1) for undefined/default-height in twips (1/20th of a point)floatgetHeightInPoints()get the row's height or ff (-1) for undefined/default-height in points (20*getHeight())shortgetLastCellNum()Gets the index of the last cell contained in this row PLUS ONE.intgetOutlineLevel()Returns the rows outline level.intgetPhysicalNumberOfCells()gets the number of defined cells (NOT number of cells in the actual row!).intgetRowNum()get row number this row representsHSSFCellStylegetRowStyle()Returns the whole-row cell styles.HSSFSheetgetSheet()Returns the HSSFSheet this row belongs tobooleangetZeroHeight()get whether or not to display this row with 0 heightinthashCode()booleanisFormatted()Is this row formatted? Most aren't, but some rows do have whole-row styles.java.util.Iterator<Cell>iterator()Alias forcellIterator()to allow foreach loopsvoidmoveCell(HSSFCell cell, short newColumn)Moves the supplied cell to a new column, which must not already have a cell there!voidremoveCell(Cell cell)remove the HSSFCell from this row.voidsetHeight(short height)set the row's height or set to ff (-1) for undefined/default-height.voidsetHeightInPoints(float height)set the row's height in points.voidsetRowNum(int rowIndex)set the row number of this row.voidsetRowStyle(HSSFCellStyle style)Applies a whole-row cell styling to the row.voidsetRowStyle(CellStyle style)Applies a whole-row cell styling to the row.voidsetZeroHeight(boolean zHeight)set whether or not to display this row with 0 heightvoidshiftCellsLeft(int firstShiftColumnIndex, int lastShiftColumnIndex, int step)Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the left.voidshiftCellsRight(int firstShiftColumnIndex, int lastShiftColumnIndex, int step)Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the right.
-
-
-
Method Detail
-
createCell
public HSSFCell createCell(int column)
Use this to create new cells within the row and return it.The cell that is returned is a
CellType.BLANK. The type can be changed either through callingsetCellValueorsetCellType.- Specified by:
createCellin interfaceRow- Parameters:
column- - the column number this cell represents- Returns:
- HSSFCell a high level representation of the created cell.
- Throws:
java.lang.IllegalArgumentException- if columnIndex < 0 or greater than 255, the maximum number of columns supported by the Excel binary format (.xls)
-
createCell
public HSSFCell createCell(int columnIndex, CellType type)
Use this to create new cells within the row and return it.The cell that is returned will be of the requested type. The type can be changed either through calling setCellValue or setCellType, but there is a small overhead to doing this, so it is best to create the required type up front.
- Specified by:
createCellin interfaceRow- Parameters:
columnIndex- - the column number this cell representstype- - the cell's data type- Returns:
- HSSFCell a high level representation of the created cell.
- Throws:
java.lang.IllegalArgumentException- if columnIndex < 0 or greater than 255, the maximum number of columns supported by the Excel binary format (.xls)
-
removeCell
public void removeCell(Cell cell)
remove the HSSFCell from this row.- Specified by:
removeCellin interfaceRow- Parameters:
cell- to remove
-
setRowNum
public void setRowNum(int rowIndex)
set the row number of this row.
-
getRowNum
public int getRowNum()
get row number this row represents
-
getSheet
public HSSFSheet getSheet()
Returns the HSSFSheet this row belongs to
-
getOutlineLevel
public int getOutlineLevel()
Returns the rows outline level. Increased as you put it into more groups (outlines), reduced as you take it out of them.- Specified by:
getOutlineLevelin interfaceRow
-
moveCell
public void moveCell(HSSFCell cell, short newColumn)
Moves the supplied cell to a new column, which must not already have a cell there!- Parameters:
cell- The cell to movenewColumn- The new column number (0 based)
-
getCell
public HSSFCell getCell(int cellnum)
Get the hssfcell representing a given column (logical cell) 0-based. If you ask for a cell that is not defined then you get a null, unless you have set a differentRow.MissingCellPolicyon the base workbook.- Specified by:
getCellin interfaceRow- Parameters:
cellnum- 0 based column number- Returns:
- HSSFCell representing that column or null if undefined.
- See Also:
Row.getCell(int, org.apache.poi.ss.usermodel.Row.MissingCellPolicy)
-
getCell
public HSSFCell getCell(int cellnum, Row.MissingCellPolicy policy)
Get the hssfcell representing a given column (logical cell) 0-based. If you ask for a cell that is not defined, then your supplied policy says what to do
-
getFirstCellNum
public short getFirstCellNum()
get the number of the first cell contained in this row.- Specified by:
getFirstCellNumin interfaceRow- Returns:
- short representing the first logical cell in the row, or -1 if the row does not contain any cells.
-
getLastCellNum
public short getLastCellNum()
Gets the index of the last cell contained in this row PLUS ONE. The result also happens to be the 1-based column number of the last cell. This value can be used as a standard upper bound when iterating over cells:short minColIx = row.getFirstCellNum(); short maxColIx = row.getLastCellNum(); for(short colIx=minColIx; colIx<maxColIx; colIx++) { HSSFCell cell = row.getCell(colIx); if(cell == null) { continue; } //... do something with cell }- Specified by:
getLastCellNumin interfaceRow- Returns:
- short representing the last logical cell in the row PLUS ONE, or -1 if the row does not contain any cells.
-
getPhysicalNumberOfCells
public int getPhysicalNumberOfCells()
gets the number of defined cells (NOT number of cells in the actual row!). That is to say if only columns 0,4,5 have values then there would be 3.- Specified by:
getPhysicalNumberOfCellsin interfaceRow- Returns:
- int representing the number of defined cells in the row.
-
setHeight
public void setHeight(short height)
set the row's height or set to ff (-1) for undefined/default-height. Set the height in "twips" or 1/20th of a point.
-
setZeroHeight
public void setZeroHeight(boolean zHeight)
set whether or not to display this row with 0 height- Specified by:
setZeroHeightin interfaceRow- Parameters:
zHeight- height is zero or not.
-
getZeroHeight
public boolean getZeroHeight()
get whether or not to display this row with 0 height- Specified by:
getZeroHeightin interfaceRow- Returns:
- - zHeight height is zero or not.
-
setHeightInPoints
public void setHeightInPoints(float height)
set the row's height in points.- Specified by:
setHeightInPointsin interfaceRow- Parameters:
height- row height in points,-1means to use the default height
-
getHeight
public short getHeight()
get the row's height or ff (-1) for undefined/default-height in twips (1/20th of a point)
-
getHeightInPoints
public float getHeightInPoints()
get the row's height or ff (-1) for undefined/default-height in points (20*getHeight())- Specified by:
getHeightInPointsin interfaceRow- Returns:
- rowheight or 0xff for undefined (use sheet default)
- See Also:
Sheet.getDefaultRowHeightInPoints()
-
isFormatted
public boolean isFormatted()
Is this row formatted? Most aren't, but some rows do have whole-row styles. For those that do, you can get the formatting fromgetRowStyle()- Specified by:
isFormattedin interfaceRow
-
getRowStyle
public HSSFCellStyle getRowStyle()
Returns the whole-row cell styles. Most rows won't have one of these, so will return null. CallisFormatted()to check first.- Specified by:
getRowStylein interfaceRow
-
setRowStyle
public void setRowStyle(HSSFCellStyle style)
Applies a whole-row cell styling to the row.
-
setRowStyle
public void setRowStyle(CellStyle style)
Applies a whole-row cell styling to the row.- Specified by:
setRowStylein interfaceRow
-
cellIterator
public java.util.Iterator<Cell> cellIterator()
- Specified by:
cellIteratorin interfaceRow- Returns:
- cell iterator of the physically defined cells.
Note that the 4th element might well not be cell 4, as the iterator
will not return un-defined (null) cells.
Call getCellNum() on the returned cells to know which cell they are.
As this only ever works on physically defined cells,
the
Row.MissingCellPolicyhas no effect.
-
iterator
public java.util.Iterator<Cell> iterator()
Alias forcellIterator()to allow foreach loops- Specified by:
iteratorin interfacejava.lang.Iterable<Cell>
-
compareTo
public int compareTo(HSSFRow other)
Compares twoHSSFRowobjects. Two rows are equal if they belong to the same worksheet and their row indexes are equal.- Specified by:
compareToin interfacejava.lang.Comparable<HSSFRow>- Parameters:
other- theHSSFRowto be compared.- Returns:
-
the value
0if the row number of thisHSSFRowis equal to the row number of the argumentHSSFRow -
a value less than
0if the row number of this thisHSSFRowis numerically less than the row number of the argumentHSSFRow -
a value greater than
0if the row number of this thisHSSFRowis numerically greater than the row number of the argumentHSSFRow
-
the value
- Throws:
java.lang.IllegalArgumentException- if the argument row belongs to a different worksheet
-
equals
public boolean equals(java.lang.Object obj)
- Overrides:
equalsin classjava.lang.Object
-
hashCode
public int hashCode()
- Overrides:
hashCodein classjava.lang.Object
-
shiftCellsRight
public void shiftCellsRight(int firstShiftColumnIndex, int lastShiftColumnIndex, int step)Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the right.- Specified by:
shiftCellsRightin interfaceRow- Parameters:
firstShiftColumnIndex- the column to start shiftinglastShiftColumnIndex- the column to end shiftingstep- length of the shifting step
-
shiftCellsLeft
public void shiftCellsLeft(int firstShiftColumnIndex, int lastShiftColumnIndex, int step)Shifts column range [firstShiftColumnIndex-lastShiftColumnIndex] step places to the left.- Specified by:
shiftCellsLeftin interfaceRow- Parameters:
firstShiftColumnIndex- the column to start shiftinglastShiftColumnIndex- the column to end shiftingstep- length of the shifting step
-
-