您的位置:首页 > 编程语言 > Java开发

Excel日期/时间存储数值转换为具体日期/时间(java实现)

2016-09-16 15:27 756 查看
在用POI的事件模型eventusermodel读取大容量Excel时发现读取的日期、时间格式输出后是浮点数字符串,然而没有找到有类似于usermodel的分格式读取的方法,于是编写一个工具类,把获取的浮点数转换成日期/时间格式,增加可用性。

Excel用浮点数标记日期时间,整数位代表日期,小数位代表时间。

代码如下:

package Util;

import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.GregorianCalendar;

/**
* Created by yijie on 9/15/16.
*/
public class StringToDate {
private static final int SECONDS_PER_MINUTE = 60;
private static final int MINUTES_PER_HOUR = 60;
private static final int HOURS_PER_DAY = 24;
private static final int SECONDS_PER_DAY = (HOURS_PER_DAY * MINUTES_PER_HOUR * SECONDS_PER_MINUTE);
/**
一天的毫秒数
**/
private static final long DAY_MILLISECONDS = SECONDS_PER_DAY * 1000L;

private static SimpleDateFormat sdFormat;

/**
转换方法
@parma numberString 要转换的浮点数
@parma format 要获得的格式 例如"hh:mm:ss"
**/
public static String toDate(double numberString, String format) {
sdFormat = new SimpleDateFormat(format);
int wholeDays = (int)Math.floor(numberString);
int millisecondsInday = (int)((numberString - wholeDays) * DAY_MILLISECONDS + 0.5);
Calendar calendar = new GregorianCalendar();
setCalendar(calendar, wholeDays, millisecondsInday, false);
return sdFormat.format(calendar.getTime());

}
private static void setCalendar(Calendar calendar, int wholeDays,
int millisecondsInDay, boolean use1904windowing) {
int startYear = 1900;
int dayAdjust = -1; // Excel thinks 2/29/1900 is a valid date, which it isn't
if (use1904windowing) {
startYear = 1904;
dayAdjust = 1; // 1904 date windowing uses 1/2/1904 as the first day
}
else if (wholeDays < 61) {
// Date is prior to 3/1/1900, so adjust because Excel thinks 2/29/1900 exists
// If Excel date == 2/29/1900, will become 3/1/1900 in Java representation
dayAdjust = 0;
}
calendar.set(startYear,0, wholeDays + dayAdjust, 0, 0, 0);
calendar.set(GregorianCalendar.MILLISECOND, millisecondsInDay);
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java excel
相关文章推荐