Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

java.text.ParseException: Unparseable date: "2014-06-04" (at offset 5)

I want to parse the date into a desired format but i am receiving an exception every time. i know it is easy to implement but i am facing some problem don't know where exactly.:

Exception: java.text.ParseException: Unparseable date: "2014-06-04" (at offset 5)

Following is my code:

private String getconvertdate(String date) {
    DateFormat inputFormat = new SimpleDateFormat("yyyy-MMM-dd HH:mm:ss",Locale.ENGLISH);
    inputFormat.setTimeZone(TimeZone.getTimeZone("UTC"));
    DateFormat outputFormat = new SimpleDateFormat("dd-MMM-yyyy",Locale.ENGLISH);
    Date parsed = null;
    try {
        parsed = inputFormat.parse(date);
    } catch (ParseException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    String outputText = outputFormat.format(parsed);
    return outputText;
}

Input to method: 2014-06-04

Expected Output: 06-Jun-2014

I have followed some Ref. from Stackoverflow.com, but still he problem persist. Please Help.

like image 569
Anchit Mittal Avatar asked Jun 04 '14 06:06

Anchit Mittal


3 Answers

You have no time part in your string: and the Month has only two character replace

new SimpleDateFormat("yyyy-MMM-dd HH:mm:ss",Locale.ENGLISH);

with

new SimpleDateFormat("yyyy-MM-dd",Locale.ENGLISH);
like image 193
Jens Avatar answered Nov 04 '22 00:11

Jens


// Try this way,hope this will help you to solve your problem....

public String convertDateStringFormat(String strDate, String fromFormat, String toFormat){
       try{
          SimpleDateFormat sdf = new SimpleDateFormat(fromFormat);
          sdf.setTimeZone(TimeZone.getTimeZone("UTC"));
          SimpleDateFormat dateFormat2 = new SimpleDateFormat(toFormat.trim());
          return dateFormat2.format(sdf.parse(strDate));
       }catch (Exception e) {
          e.printStackTrace();
          return "";
       }
}
like image 7
Haresh Chhelana Avatar answered Nov 03 '22 23:11

Haresh Chhelana


Maybe you need to tackle different input formats Then catch the currently unmanaged format exception (just a sample):

private String getconvertdate(String date) {
    System.out.println(date.length());
    DateFormat inputFormat = null;
            if(date.length() == 20)
                inputFormat = new SimpleDateFormat("yyyy-MMM-dd HH:mm:ss",Locale.ENGLISH);
    if(date.length() == 10)
        inputFormat = new SimpleDateFormat("yyyy-MM-dd",Locale.ENGLISH) ;

    if(null == inputFormat)
        return "Format invalid";

    inputFormat.setTimeZone(TimeZone.getTimeZone("UTC"));
    DateFormat outputFormat = new SimpleDateFormat("dd-MMM-yyyy",Locale.ENGLISH);
    Date parsed = null;
    try {
        parsed = inputFormat.parse(date);
    } catch (ParseException e) {
        return "Input Date invalid";
    }
    String outputText = outputFormat.format(parsed);
    return outputText;
}
like image 3
Abs Avatar answered Nov 03 '22 23:11

Abs