public interface Name
A name is a meaningful shorthand that makes it easier to understand the purpose of a cell reference, constant or a formula.
Examples:Sheet sheet = workbook.createSheet("Loan Calculator"); Name name; name = workbook.createName(); name.setNameName("Interest_Rate"); name.setRefersToFormula("'Loan Calculator'!$E$5"); name = wb.createName(); name.setNameName("Loan_Amount"); name.setRefersToFormula("'Loan Calculator'!$E$4"); name = wb.createName(); name.setNameName("Number_of_Payments"); name.setRefersToFormula("'Loan Calculator'!$E$10"); name = wb.createName(); name.setNameName("Monthly_Payment"); name.setRefersToFormula("-PMT(Interest_Rate/12,Number_of_Payments,Loan_Amount)"); name = wb.createName(); name.setNameName("Values_Entered"); name.setRefersToFormula("IF(Loan_Amount*Interest_Rate>0,1,0)");
Modifier and Type | Method and Description |
---|---|
String |
getComment()
Returns the comment the user provided when the name was created.
|
String |
getNameName()
Gets the name of the named range
|
String |
getRefersToFormula()
Returns the formula that the name is defined to refer to.
|
int |
getSheetIndex()
Returns the sheet index this name applies to.
|
String |
getSheetName()
Get the sheets name which this named range is referenced to
|
boolean |
isDeleted()
Checks if this name points to a cell that no longer exists
|
boolean |
isFunctionName()
Checks if this name is a function name
|
void |
setComment(String comment)
Sets the comment the user provided when the name was created.
|
void |
setFunction(boolean value)
Indicates that the defined name refers to a user-defined function.
|
void |
setNameName(String name)
Sets the name of the named range
|
void |
setRefersToFormula(String formulaText)
Sets the formula that the name is defined to refer to.
|
void |
setSheetIndex(int sheetId)
Tell Excel that this name applies to the worksheet with the specified index instead of the entire workbook.
|
String getSheetName()
String getNameName()
void setNameName(String name)
The following is a list of syntax rules that you need to be aware of when you create and edit names.
A name must always be unique within its scope. POI prevents you from defining a name that is not unique within its scope. However you can use the same name in different scopes. Example:
//by default names are workbook-global Name name; name = workbook.createName(); name.setNameName("sales_08"); name = workbook.createName(); name.setNameName("sales_08"); //will throw an exception: "The workbook already contains this name (case-insensitive)" //create sheet-level name name = workbook.createName(); name.setSheetIndex(0); //the scope of the name is the first sheet name.setNameName("sales_08"); //ok name = workbook.createName(); name.setSheetIndex(0); name.setNameName("sales_08"); //will throw an exception: "The sheet already contains this name (case-insensitive)"
name
- named range name to setIllegalArgumentException
- if the name is invalid or the already exists within its scope (case-insensitive)String getRefersToFormula()
null
if it has not been set yet. Never empty stringsetRefersToFormula(String)
void setRefersToFormula(String formulaText)
'My Sheet'!$A$3
8.3
HR!$A$1:$Z$345
SUM(Sheet1!A1,Sheet2!B2)
-PMT(Interest_Rate/12,Number_of_Payments,Loan_Amount)
formulaText
- the reference for this nameIllegalArgumentException
- if the specified formulaText is unparsableboolean isFunctionName()
boolean isDeleted()
true
if the name refers to a deleted cell, false
otherwisevoid setSheetIndex(int sheetId)
sheetId
- the sheet index this name applies to, -1 unsets this property making the name workbook-globalIllegalArgumentException
- if the sheet index is invalid.int getSheetIndex()
String getComment()
void setComment(String comment)
comment
- the user comment for this named rangevoid setFunction(boolean value)
value
- true
indicates the name refers to a function.Copyright © 2020. All rights reserved.