我想将ISO时间格式转换为yyyy-mm-dd hh:mm:ss.SSS。但是我无法实现转换。我刚接触pig,并试图编写一个UDF来处理从ISO格式到yyyy-mm-dd hh:mm:ss.SSS的转换。
请指导我,我尝试了pig的内置函数(FORMAT,DATE_FORMAT),但无法将数据转换为所需格式。
当前数据格式:2013-08-22T13:23:18.226220+01:00
所需数据格式:2013-08-22 13:23:18.226
请指导我,我尝试了pig的内置函数(FORMAT,DATE_FORMAT),但无法将数据转换为所需格式。
当前数据格式:2013-08-22T13:23:18.226220+01:00
所需数据格式:2013-08-22 13:23:18.226
import java.io.IOException;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import org.apache.pig.EvalFunc;
import org.apache.pig.data.Tuple;
import org.apache.pig.EvalFunc;
import org.joda.time.DateTime;
import org.joda.time.format.*;
import org.joda.time.format.DateTimeFormatter;
import org.joda.time.format.DateTimeFormatterBuilder;
public class test extends EvalFunc<String>{
public String exec(Tuple input) throws IOException {
if ((input == null) || (input.size() == 0))
return null;
try{
String time = (String)input.get(0);
DateFormat dt = new SimpleDateFormat ("yyyy-mm-dd hh:mm:ss.SSS");
Date d_t = dt.parse(time);
String timedt = getTimedt(d_t);
return timedt;
} catch (ParseException e) {
return null;
}
}
private String getTimedt(Date d_t) {
DateTimeFormatterBuilder formatter = new DateTimeFormatterBuilder();
}
}
我该如何在Pig中处理日期转换?