aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--poi/src/main/java/org/apache/poi/ss/usermodel/DataFormatter.java18
-rw-r--r--poi/src/test/java/org/apache/poi/ss/usermodel/TestDataFormatter.java30
2 files changed, 47 insertions, 1 deletions
diff --git a/poi/src/main/java/org/apache/poi/ss/usermodel/DataFormatter.java b/poi/src/main/java/org/apache/poi/ss/usermodel/DataFormatter.java
index f9a1fedc5f..7a18d30e68 100644
--- a/poi/src/main/java/org/apache/poi/ss/usermodel/DataFormatter.java
+++ b/poi/src/main/java/org/apache/poi/ss/usermodel/DataFormatter.java
@@ -204,7 +204,7 @@ public class DataFormatter {
private final Map<String,Format> formats = new HashMap<>();
/** whether CSV friendly adjustments should be made to the formatted text **/
- private final boolean emulateCSV;
+ private boolean emulateCSV = false;
/** whether years in dates should be displayed with 4 digits even if the formatString specifies only 2 **/
private boolean use4DigitYearsInAllDateFormats = false;
@@ -276,6 +276,22 @@ public class DataFormatter {
}
/**
+ * @param emulateCSV whether to emulate CSV output (default false).
+ * @since POI 5.2.0
+ */
+ public void setEmulateCSV(boolean emulateCSV) {
+ this.emulateCSV = emulateCSV;
+ }
+
+ /**
+ * @return whether to emulate CSV output (default false).
+ * @since POI 5.2.0
+ */
+ public boolean isEmulateCSV() {
+ return emulateCSV;
+ }
+
+ /**
* @param useCachedValuesForFormulaCells if set to true, when you do not provide a {@link FormulaEvaluator},
* for cells with formulas, we will return the cached value for the cell (if available),
* otherwise - we return the formula itself.
diff --git a/poi/src/test/java/org/apache/poi/ss/usermodel/TestDataFormatter.java b/poi/src/test/java/org/apache/poi/ss/usermodel/TestDataFormatter.java
index ebc657bac7..21744b9b88 100644
--- a/poi/src/test/java/org/apache/poi/ss/usermodel/TestDataFormatter.java
+++ b/poi/src/test/java/org/apache/poi/ss/usermodel/TestDataFormatter.java
@@ -83,6 +83,36 @@ class TestDataFormatter {
+ "Having: " + System.getProperty("user.language") + "/" + System.getProperty("user.country"));
}
+ @Test
+ void setEmulateCSV() {
+ DataFormatter dataFormatter = new DataFormatter();
+ assertFalse(dataFormatter.isEmulateCSV());
+ dataFormatter.setEmulateCSV(true);
+ assertTrue(dataFormatter.isEmulateCSV());
+ dataFormatter.setEmulateCSV(false);
+ assertFalse(dataFormatter.isEmulateCSV());
+ }
+
+ @Test
+ void setUse4DigitYearsInAllDateFormats() {
+ DataFormatter dataFormatter = new DataFormatter();
+ assertFalse(dataFormatter.use4DigitYearsInAllDateFormats());
+ dataFormatter.setUse4DigitYearsInAllDateFormats(true);
+ assertTrue(dataFormatter.use4DigitYearsInAllDateFormats());
+ dataFormatter.setUse4DigitYearsInAllDateFormats(false);
+ assertFalse(dataFormatter.use4DigitYearsInAllDateFormats());
+ }
+
+ @Test
+ void useCachedValuesForFormulaCells() {
+ DataFormatter dataFormatter = new DataFormatter();
+ assertFalse(dataFormatter.useCachedValuesForFormulaCells());
+ dataFormatter.setUseCachedValuesForFormulaCells(true);
+ assertTrue(dataFormatter.useCachedValuesForFormulaCells());
+ dataFormatter.setUseCachedValuesForFormulaCells(false);
+ assertFalse(dataFormatter.useCachedValuesForFormulaCells());
+ }
+
/**
* Test that we use the specified locale when deciding
* how to format normal numbers