今天在解析apache usertrack模块产生的clickstream日志文件时,其中有一个接收请求的时间,其格式为:
27/Feb/2008:10:12:44 +0800
在用SimpleDateFormat解析时始终出错.后来的解决办法:
SimpleDateFormat formatter = new SimpleDateFormat("dd/MMM/yyyy:hh:mm:ss Z", Locale.ENGLISH);
formatter.parse(strDateTime);
这段代码就可以解析上面的时间字符串了.
原因是:
1.+0800表示的是时区的信息,用Z可以解析
2.Feb这个月份只有用Locale.ENGLISH才能解析,如果用缺省的new SimpleDateFormat("dd/MMM/yyyy:hh:mm:ss Z"),
这时解析器使用的是Locale.getDefault(),即Local.Chinese,而Feb在中文里并没有定义是几月,所以解析会出错.
如果时间字符串是"27/一月/2008:10:12:44 +0800",注意英文简称的月份已经变为中文的月份,这时用确认的Locale是可以正确解析的.即:
SimpleDateFormat formatter = new SimpleDateFormat("dd/MMM/yyyy:hh:mm:ss Z");
formatter.parse(strDateTime);
或者:
SimpleDateFormat formatter = new SimpleDateFormat("dd/MMM/yyyy:hh:mm:ss Z", Locale.CHINESE);
formatter.parse(strDateTime);