Pergunta

Eu tentando analisar um conjunto de dados em um formato MySql, eu corri em toda SimpleDateFormat. Eu posso obter o dia adequado e mês, mas eu tenho um resultado estranho para o ano:

date = 2009-06-22;
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); 
Date d = sdf.parse(date);
System.println(date);
System.println(d.getDate());
System.println(d.getMonth());
System.println(d.getYear());

Saídas:

2009-06-22
22           OK
5            Hum... Ok, months go from 0 to 11
109          o_O WTF ?

Eu tentei mudar o formato para YYYY-MM-dd (tenho um erro) e yy-MM-dd (não fez nada). Estou programando em Android, não sei se é importante.

Por enquanto, eu desvio que o uso de uma divisão, mas é sujo e me impedir de usar os recursos i18n.

Foi útil?

Solução

O ano é em relação a 1900. Isso é um "recurso" da classe Date. Tente usar Calender.

Outras dicas

Graças a Aaron, a versão correta:

Calendar c = Calendar.getInstance(); 
c.setTime(sdf.parse(date));
System.println(c.get(Calendar.YEAR));
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top