summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPJ Fanning <fanningpj@apache.org>2021-10-19 18:25:33 +0000
committerPJ Fanning <fanningpj@apache.org>2021-10-19 18:25:33 +0000
commit77786178ea9e9be63089d4e38b172d085ebf0d2f (patch)
treeeb09a4487585a342bb6141294891101a41ecba8b
parent67008b311449e25c17411ba5b1a36eaf0fd309ee (diff)
downloadpoi-77786178ea9e9be63089d4e38b172d085ebf0d2f.tar.gz
poi-77786178ea9e9be63089d4e38b172d085ebf0d2f.zip
[bug-65644] Improved regex for Excel accounting formats. Thanks to Adam DeSapio
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1894386 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--poi/src/main/java/org/apache/poi/ss/format/CellFormatPart.java5
-rw-r--r--poi/src/test/java/org/apache/poi/ss/format/TestCellFormat.java20
-rw-r--r--poi/src/test/java9/module-info.classbin4198 -> 4145 bytes
3 files changed, 24 insertions, 1 deletions
diff --git a/poi/src/main/java/org/apache/poi/ss/format/CellFormatPart.java b/poi/src/main/java/org/apache/poi/ss/format/CellFormatPart.java
index abb9978242..141c98e735 100644
--- a/poi/src/main/java/org/apache/poi/ss/format/CellFormatPart.java
+++ b/poi/src/main/java/org/apache/poi/ss/format/CellFormatPart.java
@@ -108,7 +108,7 @@ public class CellFormatPart {
" \\s*(-?[0-9]+(?:\\.[0-9]*)?)\\s* # The constant to test against\n";
// A currency symbol / string, in a specific locale
- String currency = "(\\[\\$.{0,3}-[0-9a-f]{3}\\])";
+ String currency = "(\\[\\$.{0,3}(-[0-9a-f]{3,4})?\\])";
String color =
"\\[(black|blue|cyan|green|magenta|red|white|yellow|color [0-9]+)\\]";
@@ -307,6 +307,9 @@ public class CellFormatPart {
if (currencyPart.startsWith("[$-")) {
// Default $ in a different locale
currencyRepl = "$";
+ } else if (!currencyPart.contains("-")) {
+ // Accounting formats such as USD [$USD]
+ currencyRepl = currencyPart.substring(2, currencyPart.indexOf("]"));
} else {
currencyRepl = currencyPart.substring(2, currencyPart.lastIndexOf('-'));
}
diff --git a/poi/src/test/java/org/apache/poi/ss/format/TestCellFormat.java b/poi/src/test/java/org/apache/poi/ss/format/TestCellFormat.java
index 3c0476a9c3..89badeded2 100644
--- a/poi/src/test/java/org/apache/poi/ss/format/TestCellFormat.java
+++ b/poi/src/test/java/org/apache/poi/ss/format/TestCellFormat.java
@@ -940,12 +940,20 @@ class TestCellFormat {
// French style accounting, euro sign comes after not before
String formatFR = "_-#,##0* [$"+euro+"-40C]_-;\\-#,##0* [$"+euro+"-40C]_-;_-\"-\"??* [$"+euro+"-40C] _-;_-@_-";
+ // R English (South Africa) style accounting, R currency symbol and 4-digit locale specifier
+ String formatSA = "_-[$R-1C09]* #,##0_-;\\-[$R-1C09]* #,##0_-;_-[$R-1C09]* \"-\"??_-;_-@_-";
+ // USD style accounting, USD currency symbol without -xxx or -xxxx locale specifier
+ String formatUSD = "_([$USD]\\ * #,##0_);_([$USD]\\ * \\(#,##0\\);_([$USD]\\ * \"-\"??_);_(@_)";
+
// Has +ve, -ve and zero rules
CellFormat cfDft = CellFormat.getInstance(formatDft);
CellFormat cfUS = CellFormat.getInstance(formatUS);
CellFormat cfUK = CellFormat.getInstance(formatUK);
CellFormat cfFR = CellFormat.getInstance(formatFR);
+ CellFormat cfSA = CellFormat.getInstance(formatSA);
+ CellFormat cfUSD = CellFormat.getInstance(formatUSD);
+
// For +ve numbers, should be Space + currency symbol + spaces + whole number with commas + space
// (Except French, which is mostly reversed...)
assertEquals(" $ 12 ", cfDft.apply(12.33).text);
@@ -953,22 +961,34 @@ class TestCellFormat {
assertEquals(" "+pound+" 12 ", cfUK.apply(12.33).text);
assertEquals(" 12 "+euro+" ", cfFR.apply(12.33).text);
+ assertEquals(" R 12 ", cfSA.apply(Double.valueOf(12.33)).text);
+ assertEquals(" USD 12 ", cfUSD.apply(Double.valueOf(12.33)).text);
+
assertEquals(" $ 16,789 ", cfDft.apply(16789.2).text);
assertEquals(" $ 16,789 ", cfUS.apply(16789.2).text);
assertEquals(" "+pound+" 16,789 ", cfUK.apply(16789.2).text);
assertEquals(" 16,789 "+euro+" ", cfFR.apply(16789.2).text);
+ assertEquals(" R 16,789 ", cfSA.apply(Double.valueOf(16789.2)).text);
+ assertEquals(" USD 16,789 ", cfUSD.apply(Double.valueOf(16789.2)).text);
+
// For -ve numbers, gets a bit more complicated...
assertEquals("-$ 12 ", cfDft.apply(-12.33).text);
assertEquals(" $ -12 ", cfUS.apply(-12.33).text);
assertEquals("-"+pound+" 12 ", cfUK.apply(-12.33).text);
assertEquals("-12 "+euro+" ", cfFR.apply(-12.33).text);
+ assertEquals("-R 12 ", cfSA.apply(Double.valueOf(-12.33)).text);
+ assertEquals(" USD (12)", cfUSD.apply(Double.valueOf(-12.33)).text);
+
assertEquals("-$ 16,789 ", cfDft.apply(-16789.2).text);
assertEquals(" $ -16,789 ", cfUS.apply(-16789.2).text);
assertEquals("-"+pound+" 16,789 ", cfUK.apply(-16789.2).text);
assertEquals("-16,789 "+euro+" ", cfFR.apply(-16789.2).text);
+ assertEquals("-R 16,789 ", cfSA.apply(Double.valueOf(-16789.2)).text);
+ assertEquals(" USD (16,789)", cfUSD.apply(Double.valueOf(-16789.2)).text);
+
// For zero, should be Space + currency symbol + spaces + Minus + spaces
assertEquals(" $ - ", cfDft.apply((double) 0).text);
assertEquals(" $ - ", cfUS.apply((double) 0).text);
diff --git a/poi/src/test/java9/module-info.class b/poi/src/test/java9/module-info.class
index 438e778ab5..028b943d0a 100644
--- a/poi/src/test/java9/module-info.class
+++ b/poi/src/test/java9/module-info.class
Binary files differ