Проблема преобразования формата даты в Java - PullRequest
2 голосов
/ 16 марта 2011

У меня есть строка в виде МММ / дд / гггг, т.е. Май / 21/2010. Теперь я хочу преобразовать его в yyyyMMdd, т.е. 20100521.

Мой код:

public static void main(String[] args) {        
        ArrayList<String> dates = new ArrayList<String>();
        dates.add("Jan/13/2011");
        dates.add("Feb/03/2001");
        dates.add("Mar/19/2012");
        dates.add("Apr/20/2011");
        dates.add("May/21/2010");
        dates.add("Jun/23/2008");
        dates.add("Jul/12/2009");
        dates.add("Aug/14/2010");
        dates.add("Sep/01/2011");
        dates.add("Oct/07/2010");
        dates.add("Nov/05/2011");
        dates.add("Dec/30/2011");

        for(String s : dates) {
            System.out.println(transformPrevDate(s));
        }
    }

И способ преобразования:

public String transformPrevDate(String datoe) {
        String[] splitter = datoe.split("/");
        String m = splitter[0].toUpperCase();
        String d = splitter[1];
        String y = splitter[2];

        DateFormat formatter = new SimpleDateFormat("MMM");
        DateFormat formatter2 = new SimpleDateFormat("MM");

        try {
            Date date = formatter.parse(m);
            m = formatter2.format(date);
        } catch (ParseException e) {
            e.printStackTrace();
        }

        String date = y + m + d;

        return date;
    }

Проблема в том, что я получаю исключение Unparseable date, в мае и октябре. Я из Дании, и если я изменю его на датский "Maj" и "Okt", это будет успешно. Так что я тут не так делаю?

Ответы [ 6 ]

4 голосов
/ 16 марта 2011

Ваш transformDate метод может быть гораздо проще, например, так:

DateFormat input = new SimpleDateFormat("MMM/dd/yyyy", Locale.ENGLISH);
DateFormat output = new SimpleDateFormat("yyyyMMdd");
public String transformPrevDate(String datoe) throws ParseException {
    return output.format(input.parse(datoe));
}

Вам не нужно выполнять анализ самостоятельно.

2 голосов
/ 16 марта 2011

Используйте SimpleDateFormat(String pattern, Locale locale), чтобы добавить Locale к разбору даты (для английского, используйте Locale.ENGLISH).

Лучшее решение:

public String transformPrevDate(String datoe) {
    SimpleDateFormat dateFormat = new SimpleDateFormat("MMM/dd/yyyy", Locale.ENGLISH);
    SimpleDateFormat dateFormat2 = new SimpleDateFormat("yyyyMMdd");

    try {
        return dateFormat2.format(dateFormat.parse(datoe));
    } catch (ParseException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
}
2 голосов
/ 16 марта 2011

Вам нужно будет применить локаль к SimpleDateFormat .

Вот более короткая версия: -

public String transformPrevDate(String date) {
    DateFormat oldFormat = new SimpleDateFormat("MMM/dd/yyyy", Locale.ENGLISH);
    DateFormat newFormat = new SimpleDateFormat("yyyyMMdd", Locale.ENGLISH);

    String formattedDate = "";

    try {
        formattedDate = newFormat.format(oldFormat.parse(date));
    }
    catch (ParseException e) {
        e.printStackTrace();
    }

    return formattedDate;
}

@Test
public void testTransformPrevDate() {
    assertEquals("20110113", transformPrevDate("Jan/13/2011"));
    assertEquals("20010203", transformPrevDate("Feb/03/2001"));
}
1 голос
/ 16 марта 2011

SimpleDateFormat зависит от локали и по умолчанию использует вашу собственную локаль. Если вы хотите использовать языковой стандарт на английском языке, вы можете создать его путем , передав Locale при создании SimpleDateFormat.

Чтобы использовать локали в США, измените инициализацию SimpleDateFormat на:

    DateFormat formatter = new SimpleDateFormat("MMM", Locale.US);
    DateFormat formatter2 = new SimpleDateFormat("MM", Locale.US);
1 голос
/ 16 марта 2011

использовать SimpleDateFormat(String pattern, Locale locale);

0 голосов
/ 16 марта 2011

SimpleDateFormat использует вашу локаль - поэтому ваш компьютер, вероятно, по умолчанию настроен на использование датского языка. Укажите английскую локаль в явном виде:

DateFormat formatter = new SimpleDateFormat("MMM", Locale.ENGLISH);
...