diff --git a/src/java/org/apache/poi/hssf/usermodel/HSSFDateUtil.java b/src/java/org/apache/poi/hssf/usermodel/HSSFDateUtil.java index 3a1a8f09b..a12f12623 100644 --- a/src/java/org/apache/poi/hssf/usermodel/HSSFDateUtil.java +++ b/src/java/org/apache/poi/hssf/usermodel/HSSFDateUtil.java @@ -148,10 +148,46 @@ public class HSSFDateUtil return null; } } + + /** + * Given a format ID and its format String, will check to see if the + * format represents a date format or not. + * Firstly, it will check to see if the format ID corresponds to an + * internal excel date format (eg most US date formats) + * If not, it will check to see if the format string only contains + * date formatting characters (ymd-/), which covers most + * non US date formats. + * + * @param formatIndex The index of the format, eg from ExtendedFormatRecord.getFormatIndex + * @param formatString The format string + */ + public static boolean isADateFormat(int formatIndex, String formatString) { + // First up, is this an internal date format? + if(isInternalDateFormat(formatIndex)) { + return true; + } + + // If we didn't get a real string, it can't be + if(formatString == null || formatString.length() == 0) { + return false; + } + + // Translate \- into just -, before matching + String fs = formatString.replace("\\-","-"); + + // Otherwise, check it's only made up of: + // y m d - / + if(fs.matches("^[ymd\\-/]+$")) { + return true; + } + + return false; + } /** - * given a format ID this will check whether the format represents - * an internal date format or not. + * Given a format ID this will check whether the format represents + * an internal excel date format or not. + * @see isDateFormat(int,String) */ public static boolean isInternalDateFormat(int format) { boolean retval =false; diff --git a/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFDateUtil.java b/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFDateUtil.java index 01539f093..ddf20fd77 100644 --- a/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFDateUtil.java +++ b/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFDateUtil.java @@ -182,6 +182,56 @@ public class TestHSSFDateUtil HSSFDateUtil.getExcelDate(javaDate), oneMinute); } } + + /** + * Tests that we correctly detect date formats as such + */ + public void testIdentifyDateFormats() { + // First up, try with a few built in date formats + short[] builtins = new short[] { 0x0e, 0x0f, 0x10, 0x16, 0x2d, 0x2e }; + for(int i=0; i