我发现自己今天也面临着日期问题,我从一个字符串格式的XML文件中提取了日期,但当我尝试将其转换为int格式时,我遇到了错误。
这是我的代码的一部分:
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(inputFile);
doc.getDocumentElement().normalize();
System.out.println("Root element :" + doc.getDocumentElement().getNodeName());
NodeList nList = doc.getElementsByTagName("top");
for (int j=0; j<= inputFile.length();j++)
for (int temp =0; temp < nList.getLength(); temp++) {
j++;
System.out.println("---------------------------------------");
Node nNode = nList.item(temp);
System.out.println("
La requete numero " +j+ " " + nNode.getNodeName());
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
dateq=eElement.getElementsByTagName("querytime").item(0).getTextContent();
System.out.println("date de la requete est " +dateq);
DateFormat dfq = new SimpleDateFormat("EEE MMM dd HH:mm:ss z yyyy", Locale.FRENCH);
Date date1 = dfq.parse(dateq);
System.out.println("new date: " +date1);
,输出为:
date de la requete est Tue Feb 08 12:30:27 +0000 2011
java.text.ParseException: Unparseable date: " Tue Feb 08 12:30:27 +0000 2011 "
问题出在您的线路
DateFormat dfq = new SimpleDateFormat("EEE MMM dd HH:mm:ss z yyyy", Locale.FRENCH);
Date date1 = dfq.parse(dateq);
您得到了ParseException
,因为在" Tue Feb 08 12:30:27 +0000 2011 "
中
您有前导空格和尾随空格,并且Tue
和Feb
部分是英语,但不是法语。
将这些行更改为
DateFormat dfq = new SimpleDateFormat("EEE MMM dd HH:mm:ss z yyyy", Locale.ENGLISH);
Date date1 = dfq.parse(dateq.trim());
并且它会起作用。