java.time.format.DateTimeParseException: Text could not be parsed at index 3

后端 未结 5 1452
醉酒成梦
醉酒成梦 2021-02-06 23:36

I am using Java 8 to parse the the date and find difference between two dates.

Here is my snippet:

String date1 =\"01-JAN-2017\";
String date2 = \"02-FEB         


        
相关标签:
5条回答
  • 2021-02-07 00:27

    The following code works. The problem is you are using "JAN" instead of "Jan". DateTimeFormatter does not recognize that it seems. and also change the pattern to "d-MMM-yyyy".

      String date1 ="01-Jan-2017";
      String date2 = "02-Feb-2017";
    
      DateTimeFormatter df = DateTimeFormatter.ofPattern("d-MMM-yyyy");
      LocalDate  d1 = LocalDate.parse(date1, df);
      LocalDate  d2 = LocalDate.parse(date2, df);
    
      Long datediff = ChronoUnit.DAYS.between(d1,d2);  
    

    Source: https://www.mkyong.com/java8/java-8-how-to-convert-string-to-localdate/

    0 讨论(0)
  • 2021-02-07 00:28

    First of all, check the javadoc. The uppercase D represents the day-of-year field (not the day-of-month as you want), and uppercase Y represents the week-based-year field (not the year as you want). The correct patterns are the lowercase letters d and y.

    Also, you're using month names in uppercase letters (JAN and FEB), so your formatter must be case insensitive (the default behaviour is to accept only values like Jan and Feb). And these month names are English abbreviations, so you must also use English locale to make sure it parses the names correctly (using java.util.Locale class).

    So, your formatter should be created like this:

    DateTimeFormatter df = new DateTimeFormatterBuilder()
        // case insensitive to parse JAN and FEB
        .parseCaseInsensitive()
        // add pattern
        .appendPattern("dd-MMM-yyyy")
        // create formatter (use English Locale to parse month names)
        .toFormatter(Locale.ENGLISH);
    

    This will make your code work (and datediff will be 32).

    0 讨论(0)
  • 2021-02-07 00:29
    // DateTimeFormatterBuilder provides custom way to create a
        // formatter
        // It is Case Insensitive, Nov , nov and NOV will be treated same
        DateTimeFormatter f = new DateTimeFormatterBuilder().parseCaseInsensitive()
                .append(DateTimeFormatter.ofPattern("yyyy-MMM-dd")).toFormatter();
        try {
            LocalDate datetime = LocalDate.parse("2019-DeC-22", f);
            System.out.println(datetime); // 2019-12-22
        } catch (DateTimeParseException e) {
            // Exception handling message/mechanism/logging as per company standard
        }
    
    0 讨论(0)
  • 2021-02-07 00:36

    Try using DateTimeFormatter dtf = DateTimeFormatter.ofPattern("dd-LLL-yyyy",Locale.ENGLISH);

    0 讨论(0)
  • 2021-02-07 00:41

    Maybe you can use this wildcard,

     String d2arr[] = {
                "2016-12-21",
                "1/17/2016",
                "1/3/2016",
                "11/23/2016",
                "OCT 20 2016",
                "Oct 22 2016",
                "Oct 23", // default year is 2016
                "OCT 24",  // default year is 2016
        };
    
        DateTimeFormatterBuilder builder = new DateTimeFormatterBuilder()
                .parseCaseInsensitive().parseLenient()
                .parseDefaulting(ChronoField.YEAR_OF_ERA, 2016L)
                .appendPattern("[yyyy-MM-dd]")
                .appendPattern("[M/dd/yyyy]")
                .appendPattern("[M/d/yyyy]")
                .appendPattern("[MM/dd/yyyy]")
                .appendPattern("[MMM dd yyyy]");
    
        DateTimeFormatter formatter2 = builder.toFormatter(Locale.ENGLISH);
    

    https://coderanch.com/t/677142/java/DateTimeParseException-Text-parsed-unparsed-textenter link description here

    0 讨论(0)
提交回复
热议问题