public class ConditionalFormattingEvaluator
extends java.lang.Object
For performance reasons, this class keeps a cache of all previously evaluated rules and cells.
Be sure to call clearAllCachedFormats()
if any conditional formats are modified, added, or deleted,
and clearAllCachedValues()
whenever cell values change.
Constructor and Description |
---|
ConditionalFormattingEvaluator(Workbook wb,
WorkbookEvaluatorProvider provider) |
Modifier and Type | Method and Description |
---|---|
void |
clearAllCachedFormats()
Call this whenever rules are added, reordered, or removed, or a rule formula is changed
(not the formula inputs but the formula expression itself)
|
void |
clearAllCachedValues()
Call this whenever cell values change in the workbook, so condional formats are re-evaluated
for all cells.
|
java.util.List<EvaluationConditionalFormatRule> |
getConditionalFormattingForCell(Cell cell)
This checks all applicable
ConditionalFormattingRule s for the cell's sheet,
in defined "priority" order, returning the matches if any. |
java.util.List<EvaluationConditionalFormatRule> |
getConditionalFormattingForCell(CellReference cellRef)
This checks all applicable
ConditionalFormattingRule s for the cell's sheet,
in defined "priority" order, returning the matches if any. |
java.util.List<EvaluationConditionalFormatRule> |
getFormatRulesForSheet(Sheet sheet)
Retrieve all formatting rules for the given sheet.
|
java.util.List<EvaluationConditionalFormatRule> |
getFormatRulesForSheet(java.lang.String sheetName)
Retrieve all formatting rules for the sheet with the given name.
|
java.util.List<Cell> |
getMatchingCells(EvaluationConditionalFormatRule rule)
Retrieve all cells where the given formatting rule evaluates to true.
|
java.util.List<Cell> |
getMatchingCells(Sheet sheet,
int conditionalFormattingIndex,
int ruleIndex)
Conditional formatting rules can apply only to cells in the sheet to which they are attached.
|
static CellReference |
getRef(Cell cell) |
protected java.util.List<EvaluationConditionalFormatRule> |
getRules(Sheet sheet)
lazy load by sheet since reading can be expensive
|
protected WorkbookEvaluator |
getWorkbookEvaluator() |
public ConditionalFormattingEvaluator(Workbook wb, WorkbookEvaluatorProvider provider)
protected WorkbookEvaluator getWorkbookEvaluator()
public void clearAllCachedFormats()
public void clearAllCachedValues()
TODO: eventually this should work like EvaluationCache.notifyUpdateCell(int, int, EvaluationCell)
and only clear values that need recalculation based on the formula dependency tree.
protected java.util.List<EvaluationConditionalFormatRule> getRules(Sheet sheet)
sheet
- The sheet to look atpublic java.util.List<EvaluationConditionalFormatRule> getConditionalFormattingForCell(CellReference cellRef)
ConditionalFormattingRule
s for the cell's sheet,
in defined "priority" order, returning the matches if any. This is a property currently
not exposed from CTCfRule
in XSSFConditionalFormattingRule
.
Most cells will have zero or one applied rule, but it is possible to define multiple rules that apply at the same time to the same cell, thus the List result.
Note that to properly apply conditional rules, care must be taken to offset the base
formula by the relative position of the current cell, or the wrong value is checked.
This is handled by WorkbookEvaluator.evaluate(String, CellReference, CellRangeAddressBase)
.
If the cell exists and is a formula cell, its cached value may be used for rule evaluation, so
make sure it is up to date. If values have changed, it is best to call
FormulaEvaluator.evaluateFormulaCell(Cell)
or FormulaEvaluator.evaluateAll()
first,
or the wrong conditional results may be returned.
cellRef
- NOTE: if no sheet name is specified, this uses the workbook active sheetEvaluationConditionalFormatRule
s that apply to the current cell value,
in priority order, as evaluated by Excel (smallest priority # for XSSF, definition order for HSSF),
or null if none applypublic java.util.List<EvaluationConditionalFormatRule> getConditionalFormattingForCell(Cell cell)
ConditionalFormattingRule
s for the cell's sheet,
in defined "priority" order, returning the matches if any. This is a property currently
not exposed from CTCfRule
in XSSFConditionalFormattingRule
.
Most cells will have zero or one applied rule, but it is possible to define multiple rules that apply at the same time to the same cell, thus the List result.
Note that to properly apply conditional rules, care must be taken to offset the base
formula by the relative position of the current cell, or the wrong value is checked.
This is handled by WorkbookEvaluator.evaluate(String, CellReference, CellRangeAddressBase)
.
If the cell exists and is a formula cell, its cached value may be used for rule evaluation, so
make sure it is up to date. If values have changed, it is best to call
FormulaEvaluator.evaluateFormulaCell(Cell)
or FormulaEvaluator.evaluateAll()
first,
or the wrong conditional results may be returned.
cell
- The cell to look forEvaluationConditionalFormatRule
s that apply to the current cell value,
in priority order, as evaluated by Excel (smallest priority # for XSSF, definition order for HSSF),
or null if none applypublic static CellReference getRef(Cell cell)
public java.util.List<EvaluationConditionalFormatRule> getFormatRulesForSheet(java.lang.String sheetName)
sheetName
- The name of the sheet to look atpublic java.util.List<EvaluationConditionalFormatRule> getFormatRulesForSheet(Sheet sheet)
sheet
- The sheet to look atpublic java.util.List<Cell> getMatchingCells(Sheet sheet, int conditionalFormattingIndex, int ruleIndex)
We could overload this with convenience methods taking a sheet name and sheet index as well.
sheet
- containing the ruleconditionalFormattingIndex
- of the ConditionalFormatting
instance in the sheet's arrayruleIndex
- of the ConditionalFormattingRule
instance within the ConditionalFormatting
public java.util.List<Cell> getMatchingCells(EvaluationConditionalFormatRule rule)
rule
- The rule to look atCopyright 2020 The Apache Software Foundation or its licensors, as applicable.