java(日期处理)
第一部分关于JAVA的Date (参考关于JAVA的Date总结)
- 1.计算某一月份的最大天数
- Calendar time=Calendar.getInstance();
- time.clear();
- time.set(Calendar.YEAR,year); //year 为 int
- time.set(Calendar.MONTH,i-1);//注意,Calendar对象默认一月为0
- int day=time.getActualMaximum(Calendar.DAY_OF_MONTH);//本月份的天数
- 注:在使用set方法之前,必须先clear一下,否则很多信息会继承自系统当前时间
- 2.Calendar和Date的转化
- (1) Calendar转化为Date
- Calendar cal=Calendar.getInstance();
- Date date=cal.getTime();
- (2) Date转化为Calendar
- Date date=new Date();
- Calendar cal=Calendar.getInstance();
- cal.setTime(date);
- 3.格式化输出日期时间 (这个用的比较多)
- Date date=new Date();
- SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
- String time=df.format(date);
- System.out.println(time);
- 4.计算一年中的第几星期
- (1)计算某一天是一年中的第几星期
- Calendar cal=Calendar.getInstance();
- cal.set(Calendar.YEAR, 2006);
- cal.set(Calendar.MONTH,;
- cal.set(Calendar.DAY_OF_MONTH, 3);
- int weekno=cal.get(Calendar.WEEK_OF_YEAR);
- (2)计算一年中的第几星期是几号
- SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd");
- Calendar cal=Calendar.getInstance();
- cal.set(Calendar.YEAR, 2006);
- cal.set(Calendar.WEEK_OF_YEAR, 1);
- cal.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY);
- System.out.println(df.format(cal.getTime()));
- 输出:
- 2006-01-02
- 5.add()和roll()的用法(不太常用)
- (1)add()方法
- SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd");
- Calendar cal=Calendar.getInstance();
- cal.set(Calendar.YEAR, 2006);
- cal.set(Calendar.MONTH,;
- cal.set(Calendar.DAY_OF_MONTH, 3);
- cal.add(Calendar.DATE, -4);
- Date date=cal.getTime();
- System.out.println(df.format(date));
- cal.add(Calendar.DATE, 4);
- date=cal.getTime();
- System.out.println(df.format(date));
- 输出:
- 2006-08-30
- 2006-09-03
- (2)roll方法
- cal.set(Calendar.YEAR, 2006);
- cal.set(Calendar.MONTH,;
- cal.set(Calendar.DAY_OF_MONTH, 3);
- cal.roll(Calendar.DATE, -4);
- date=cal.getTime();
- System.out.println(df.format(date));
- cal.roll(Calendar.DATE, 4);
- date=cal.getTime();
- System.out.println(df.format(date));
- 输出:
- 2006-09-29
- 2006-09-03
- 可见,roll()方法在本月内循环,一般使用add()方法;
- 6.计算两个任意时间中间的间隔天数(这个比较常用)
- (1)传进Calendar对象
- public int getIntervalDays(Calendar startday,Calendar endday)...{
- if(startday.after(endday))...{
- Calendar cal=startday;
- startday=endday;
- endday=cal;
- }
- long sl=startday.getTimeInMillis();
- long el=endday.getTimeInMillis();
- long ei=el-sl;
- return (int)(ei/(1000*60*60*24));
- }
- (2)传进Date对象
- public int getIntervalDays(Date startday,Date endday)...{
- if(startday.after(endday))...{
- Date cal=startday;
- startday=endday;
- endday=cal;
- }
- long sl=startday.getTime();
- long el=endday.getTime();
- long ei=el-sl;
- return (int)(ei/(1000*60*60*24));
- }
- (3)改进精确计算相隔天数的方法
- public int getDaysBetween (Calendar d1,Calendar d2) ...{
- if (d1.after(d2)) ...{
- java.util.Calendar swap = d1;
- d1 = d2;
- d2 = swap;
- }
- int days = d2.get(Calendar.DAY_OF_YEAR) - d1.get(Calendar.DAY_OF_YEAR);
- int y2 = d2.get(Calendar.YEAR);
- if (d1.get(Calendar.YEAR) != y2) ...{
- d1 = (Calendar) d1.clone();
- do ...{
- days += d1.getActualMaximum(Calendar.DAY_OF_YEAR);//得到当年的实际天数
- d1.add(Calendar.YEAR, 1);
- } while (d1.get(Calendar.YEAR) != y2);
- }
- return days;
- }
- 注意:通过上面的方法可以衍生出求任何时间,如要查出邮箱三周之内收到的邮件(得到当前系统时间-再得到三周前时间)用收件的时间去匹配 最好装化成 long去比较
- 如:1年前日期(注意毫秒的转换)
- java.util.Date myDate=new java.util.Date();
- long myTime=(myDate.getTime()/1000)-60*60*24*365;
- myDate.setTime(myTime*1000);
- String mDate=formatter.format(myDate);
- 7. String 和 Date ,Long 之间相互转换 (最常用)
- 字符串转化成时间类型(字符串可以是任意类型,只要和SimpleDateFormat中的格式一致即可)
- 通常我们取时间跨度的时候,会substring出具体时间--long-比较
- java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("M/dd/yyyy hh:mm:ss a",java.util.Locale.US);
- java.util.Date d = sdf.parse("5/13/2003 10:31:37 AM");
- long dvalue=d.getTime();
- SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
- String mDateTime1=formatter.format(d);
- 8. 通过时间求时间
- 年月周求日期
- >SimpleDateFormat formatter2 = new SimpleDateFormat("yyyy-MM F E");
- java.util.Date date2= formatter2.parse("2003-05 5 星期五");
- SimpleDateFormat formatter3 = new SimpleDateFormat("yyyy-MM-dd");
- String mydate2=formatter3.format(date2);
- 求是星期几
- mydate= myFormatter.parse("2001-1-1");
- SimpleDateFormat formatter4 = new SimpleDateFormat("E");
- String mydate3=formatter4.format(mydate);
- 9. java 和 具体的数据库结合
- 在开发web应用中,针对不同的数据库日期类型,我们需要在我们的程序中对日期类型做各种不同的转换。若对应数据库数据是oracle的Date类型,即只需要年月日的,可以选择使用java.sql.Date类型,若对应的是MSsqlserver 数据库的DateTime类型,即需要年月日时分秒的,选择java.sql.Timestamp类型
- 你可以使用dateFormat定义时间日期的格式,转一个字符串即可
- class Datetest{
- *method 将字符串类型的日期转换为一个timestamp(时间戳记java.sql.Timestamp)
- *@param dateString 需要转换为timestamp的字符串
- *@return dataTime timestamp
- public final static java.sql.Timestamp string2Time(String dateString)
- throws java.text.ParseException {
- DateFormat dateFormat;
- dateFormat = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss.SSS", Locale.ENGLISH);//设定格式
- //dateFormat = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss", Locale.ENGLISH);
- dateFormat.setLenient(false);
- java.util.Date timeDate = dateFormat.parse(dateString);//util类型
- java.sql.Timestamp dateTime = new java.sql.Timestamp(timeDate.getTime());//Timestamp类型,timeDate.getTime()返回一个long型
- return dateTime;
- }
- *method 将字符串类型的日期转换为一个Date(java.sql.Date)
- *@param dateString 需要转换为Date的字符串
- *@return dataTime Date
- public final static java.sql.Date string2Date(String dateString)
- throws java.lang.Exception {
- DateFormat dateFormat;
- dateFormat = new SimpleDateFormat("yyyy-MM-dd", Locale.ENGLISH);
- dateFormat.setLenient(false);
- java.util.Date timeDate = dateFormat.parse(dateString);//util类型
- java.sql.Date dateTime = new java.sql.Date(timeDate.getTime());//sql类型
- return dateTime;
- }
- public static void main(String[] args){
- Date da = new Date();
- 注意:这个地方da.getTime()得到的是一个long型的值
- System.out.println(da.getTime());
- 由日期date转换为timestamp
- 第一种方法:使用new Timestamp(long)
- Timestamp t = new Timestamp(new Date().getTime());
- />System.out.println(t);
- 第二种方法:使用Timestamp(int year,int month,int date,int hour,int minute,int second,int nano)
- Timestamp tt = new Timestamp(Calendar.getInstance().get(
- Calendar.YEAR) - 1900, Calendar.getInstance().get(
- Calendar.MONTH), Calendar.getInstance().get(
- Calendar.DATE), Calendar.getInstance().get(
- Calendar.HOUR), Calendar.getInstance().get(
- Calendar.MINUTE), Calendar.getInstance().get(
- Calendar.SECOND), 0);
- System.out.println(tt);
- try {
- String sToDate = "2005-8-18";//用于转换成java.sql.Date的字符串
- String sToTimestamp = "2005-8-18 14:21:12.123";//用于转换成java.sql.Timestamp的字符串
- Date date1 = string2Date(sToDate);
- Timestamp date2 = string2Time(sToTimestamp);
- System.out.println("Date:"+date1.toString());//结果显示
- System.out.println("Timestamp:"+date2.toString());//结果显示
- }catch(Exception e) {
- e.printStackTrace();
- }
- }
- }
1.计算某一月份的最大天数
Calendar time=Calendar.getInstance();
time.clear();
time.set(Calendar.YEAR,year); //year 为 int
time.set(Calendar.MONTH,i-1);//注意,Calendar对象默认一月为0
int day=time.getActualMaximum(Calendar.DAY_OF_MONTH);//本月份的天数
注:在使用set方法之前,必须先clear一下,否则很多信息会继承自系统当前时间
2.Calendar和Date的转化
(1) Calendar转化为Date
Calendar cal=Calendar.getInstance();
Date date=cal.getTime();
(2) Date转化为Calendar
Date date=new Date();
Calendar cal=Calendar.getInstance();
cal.setTime(date);
3.格式化输出日期时间 (这个用的比较多)
Date date=new Date();
SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
String time=df.format(date);
System.out.println(time);
4.计算一年中的第几星期
(1)计算某一天是一年中的第几星期
Calendar cal=Calendar.getInstance();
cal.set(Calendar.YEAR, 2006);
cal.set(Calendar.MONTH,;
cal.set(Calendar.DAY_OF_MONTH, 3);
int weekno=cal.get(Calendar.WEEK_OF_YEAR);
(2)计算一年中的第几星期是几号
SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd");
Calendar cal=Calendar.getInstance();
cal.set(Calendar.YEAR, 2006);
cal.set(Calendar.WEEK_OF_YEAR, 1);
cal.set(Calendar.DAY_OF_WEEK, Calendar.MONDAY);
System.out.println(df.format(cal.getTime()));
输出:
2006-01-02
5.add()和roll()的用法(不太常用)
(1)add()方法
SimpleDateFormat df=new SimpleDateFormat("yyyy-MM-dd");
Calendar cal=Calendar.getInstance();
cal.set(Calendar.YEAR, 2006);
cal.set(Calendar.MONTH,;
cal.set(Calendar.DAY_OF_MONTH, 3);
cal.add(Calendar.DATE, -4);
Date date=cal.getTime();
System.out.println(df.format(date));
cal.add(Calendar.DATE, 4);
date=cal.getTime();
System.out.println(df.format(date));
输出:
2006-08-30
2006-09-03
(2)roll方法
cal.set(Calendar.YEAR, 2006);
cal.set(Calendar.MONTH,;
cal.set(Calendar.DAY_OF_MONTH, 3);
cal.roll(Calendar.DATE, -4);
date=cal.getTime();
System.out.println(df.format(date));
cal.roll(Calendar.DATE, 4);
date=cal.getTime();
System.out.println(df.format(date));
输出:
2006-09-29
2006-09-03
可见,roll()方法在本月内循环,一般使用add()方法;
6.计算两个任意时间中间的间隔天数(这个比较常用)
(1)传进Calendar对象
public int getIntervalDays(Calendar startday,Calendar endday)...{
if(startday.after(endday))...{
Calendar cal=startday;
startday=endday;
endday=cal;
}
long sl=startday.getTimeInMillis();
long el=endday.getTimeInMillis();
long ei=el-sl;
return (int)(ei/(1000*60*60*24));
}
(2)传进Date对象
public int getIntervalDays(Date startday,Date endday)...{
if(startday.after(endday))...{
Date cal=startday;
startday=endday;
endday=cal;
}
long sl=startday.getTime();
long el=endday.getTime();
long ei=el-sl;
return (int)(ei/(1000*60*60*24));
}
(3)改进精确计算相隔天数的方法
public int getDaysBetween (Calendar d1,Calendar d2) ...{
if (d1.after(d2)) ...{
java.util.Calendar swap = d1;
d1 = d2;
d2 = swap;
}
int days = d2.get(Calendar.DAY_OF_YEAR) - d1.get(Calendar.DAY_OF_YEAR);
int y2 = d2.get(Calendar.YEAR);
if (d1.get(Calendar.YEAR) != y2) ...{
d1 = (Calendar) d1.clone();
do ...{
days += d1.getActualMaximum(Calendar.DAY_OF_YEAR);//得到当年的实际天数
d1.add(Calendar.YEAR, 1);
} while (d1.get(Calendar.YEAR) != y2);
}
return days;
}
注意:通过上面的方法可以衍生出求任何时间,如要查出邮箱三周之内收到的邮件(得到当前系统时间-再得到三周前时间)用收件的时间去匹配 最好装化成 long去比较
如:1年前日期(注意毫秒的转换)
java.util.Date myDate=new java.util.Date();
long myTime=(myDate.getTime()/1000)-60*60*24*365;
myDate.setTime(myTime*1000);
String mDate=formatter.format(myDate);
7. String 和 Date ,Long 之间相互转换 (最常用)
字符串转化成时间类型(字符串可以是任意类型,只要和SimpleDateFormat中的格式一致即可)
通常我们取时间跨度的时候,会substring出具体时间--long-比较
java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("M/dd/yyyy hh:mm:ss a",java.util.Locale.US);
java.util.Date d = sdf.parse("5/13/2003 10:31:37 AM");
long dvalue=d.getTime();
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String mDateTime1=formatter.format(d);
8. 通过时间求时间
年月周求日期
>SimpleDateFormat formatter2 = new SimpleDateFormat("yyyy-MM F E");
java.util.Date date2= formatter2.parse("2003-05 5 星期五");
SimpleDateFormat formatter3 = new SimpleDateFormat("yyyy-MM-dd");
String mydate2=formatter3.format(date2);
求是星期几
mydate= myFormatter.parse("2001-1-1");
SimpleDateFormat formatter4 = new SimpleDateFormat("E");
String mydate3=formatter4.format(mydate);
9. java 和 具体的数据库结合
在开发web应用中,针对不同的数据库日期类型,我们需要在我们的程序中对日期类型做各种不同的转换。若对应数据库数据是oracle的Date类型,即只需要年月日的,可以选择使用java.sql.Date类型,若对应的是MSsqlserver 数据库的DateTime类型,即需要年月日时分秒的,选择java.sql.Timestamp类型
你可以使用dateFormat定义时间日期的格式,转一个字符串即可
class Datetest{
*method 将字符串类型的日期转换为一个timestamp(时间戳记java.sql.Timestamp)
*@param dateString 需要转换为timestamp的字符串
*@return dataTime timestamp
public final static java.sql.Timestamp string2Time(String dateString)
throws java.text.ParseException {
DateFormat dateFormat;
dateFormat = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss.SSS", Locale.ENGLISH);//设定格式
//dateFormat = new SimpleDateFormat("yyyy-MM-dd kk:mm:ss", Locale.ENGLISH);
dateFormat.setLenient(false);
java.util.Date timeDate = dateFormat.parse(dateString);//util类型
java.sql.Timestamp dateTime = new java.sql.Timestamp(timeDate.getTime());//Timestamp类型,timeDate.getTime()返回一个long型
return dateTime;
}
*method 将字符串类型的日期转换为一个Date(java.sql.Date)
*@param dateString 需要转换为Date的字符串
*@return dataTime Date
public final static java.sql.Date string2Date(String dateString)
throws java.lang.Exception {
DateFormat dateFormat;
dateFormat = new SimpleDateFormat("yyyy-MM-dd", Locale.ENGLISH);
dateFormat.setLenient(false);
java.util.Date timeDate = dateFormat.parse(dateString);//util类型
java.sql.Date dateTime = new java.sql.Date(timeDate.getTime());//sql类型
return dateTime;
}
public static void main(String[] args){
Date da = new Date();
注意:这个地方da.getTime()得到的是一个long型的值
System.out.println(da.getTime());
由日期date转换为timestamp
第一种方法:使用new Timestamp(long)
Timestamp t = new Timestamp(new Date().getTime());
/>System.out.println(t);
第二种方法:使用Timestamp(int year,int month,int date,int hour,int minute,int second,int nano)
Timestamp tt = new Timestamp(Calendar.getInstance().get(
Calendar.YEAR) - 1900, Calendar.getInstance().get(
Calendar.MONTH), Calendar.getInstance().get(
Calendar.DATE), Calendar.getInstance().get(
Calendar.HOUR), Calendar.getInstance().get(
Calendar.MINUTE), Calendar.getInstance().get(
Calendar.SECOND), 0);
System.out.println(tt);
try {
String sToDate = "2005-8-18";//用于转换成java.sql.Date的字符串
String sToTimestamp = "2005-8-18 14:21:12.123";//用于转换成java.sql.Timestamp的字符串
Date date1 = string2Date(sToDate);
Timestamp date2 = string2Time(sToTimestamp);
System.out.println("Date:"+date1.toString());//结果显示
System.out.println("Timestamp:"+date2.toString());//结果显示
}catch(Exception e) {
e.printStackTrace();
}
}
}
第二部分Date工具类(参考一个总结好的很好的关于JAVA的Date工具类)
- <SPAN style="BACKGROUND-COLOR: #ffffff">public class DateUtil
- {
- //默认显示日期的格式
- public static final String DATAFORMAT_STR = "yyyy-MM-dd";
- //默认显示日期的格式
- public static final String YYYY_MM_DATAFORMAT_STR = "yyyy-MM";
- //默认显示日期时间的格式
- public static final String DATATIMEF_STR = "yyyy-MM-dd HH:mm:ss";
- //默认显示简体中文日期的格式
- public static final String ZHCN_DATAFORMAT_STR = "yyyy年MM月dd日";
- //默认显示简体中文日期时间的格式
- public static final String ZHCN_DATATIMEF_STR = "yyyy年MM月dd日HH时mm分ss秒";
- //默认显示简体中文日期时间的格式
- public static final String ZHCN_DATATIMEF_STR_4yMMddHHmm = "yyyy年MM月dd日HH时mm分";
- private static DateFormat dateFormat = null;
- private static DateFormat dateTimeFormat = null;
- private static DateFormat zhcnDateFormat = null;
- private static DateFormat zhcnDateTimeFormat = null;
- static
- {
- dateFormat = new SimpleDateFormat(DATAFORMAT_STR);
- dateTimeFormat = new SimpleDateFormat(DATATIMEF_STR);
- zhcnDateFormat = new SimpleDateFormat(ZHCN_DATAFORMAT_STR);
- zhcnDateTimeFormat = new SimpleDateFormat(ZHCN_DATATIMEF_STR);
- }
- private static DateFormat getDateFormat(String formatStr)
- {
- if (formatStr.equalsIgnoreCase(DATAFORMAT_STR))
- {
- return dateFormat;
- }
- else
- if (formatStr.equalsIgnoreCase(DATATIMEF_STR))
- {
- return dateTimeFormat;
- }
- else
- if (formatStr.equalsIgnoreCase(ZHCN_DATAFORMAT_STR))
- {
- return zhcnDateFormat;
- }
- else
- if (formatStr.equalsIgnoreCase(ZHCN_DATATIMEF_STR))
- {
- return zhcnDateTimeFormat;
- }
- else
- {
- return new SimpleDateFormat(formatStr);
- }
- }
- /**
- * 按照默认显示日期时间的格式"yyyy-MM-dd HH:mm:ss",转化dateTimeStr为Date类型
- * dateTimeStr必须是"yyyy-MM-dd HH:mm:ss"的形式
- * @param dateTimeStr
- * @return
- */
- public static Date getDate(String dateTimeStr)
- {
- return getDate(dateTimeStr, DATATIMEF_STR);
- }
- /**
- * 按照默认formatStr的格式,转化dateTimeStr为Date类型
- * dateTimeStr必须是formatStr的形式
- * @param dateTimeStr
- * @param formatStr
- * @return
- */
- public static Date getDate(String dateTimeStr, String formatStr)
- {
- try
- {
- if (dateTimeStr == null || dateTimeStr.equals(""))
- {
- return null;
- }
- DateFormat sdf = getDateFormat(formatStr);
- java.util.Date d = sdf.parse(dateTimeStr);
- return d;
- }
- catch (ParseException e)
- {
- throw new RuntimeException(e);
- }
- }
- /**
- * 将YYYYMMDD转换成Date日期
- * @param date
- * @return
- * @throws BusinessException
- */
- public static Date transferDate(String date) throws Exception
- {
- if (date == null || date.length() < 1)
- return null;
- if (date.length() != 8)
- throw new Exception("日期格式错误");
- String con = "-";
- String yyyy = date.substring(0, 4);
- String mm = date.substring(4, 6);
- String dd = date.substring(6, 8);
- int month = Integer.parseInt(mm);
- int day = Integer.parseInt(dd);
- if (month < 1 || month > 12 || day < 1 || day > 31)
- throw new Exception("日期格式错误");
- String str = yyyy + con + mm + con + dd;
- return DateUtil.getDate(str, DateUtil.DATAFORMAT_STR);
- }
- /**
- * 将YYYY-MM-DD日期转换成yyyymmdd格式字符串
- * @param date
- * @return
- */
- public static String getYYYYMMDDDate(Date date)
- {
- if (date == null)
- return null;
- String yyyy = getYear(date) + "";
- String mm = getMonth(date) + "";
- String dd = getDay(date) + "";
- mm = StringUtil.rightAlign(mm, 2, "0");
- dd = StringUtil.rightAlign(dd, 2, "0");
- return yyyy + mm + dd;
- }
- /**
- * 将YYYY-MM-DD日期转换成YYYYMMDDHHMMSS格式字符串
- * @param date
- * @return
- */
- public static String getYYYYMMDDHHMMSSDate(Date date)
- {
- if (date == null)
- return null;
- String yyyy = getYear(date) + "";
- String mm = getMonth(date) + "";
- String dd = getDay(date) + "";
- String hh = getHour(date) + "";
- String min = getMin(date) + "";
- String ss = getSecond(date) + "";
- mm = StringUtil.rightAlign(mm, 2, "0");
- dd = StringUtil.rightAlign(dd, 2, "0");
- hh = StringUtil.rightAlign(hh, 2, "0");
- min = StringUtil.rightAlign(min, 2, "0");
- ss = StringUtil.rightAlign(ss, 2, "0");
- return yyyy + mm + dd + hh + min + ss;
- }
- /**
- * 将YYYY-MM-DD日期转换成yyyymmdd格式字符串
- * @param date
- * @return
- */
- public static String getYYYYMMDDDate(String date)
- {
- return getYYYYMMDDDate(getDate(date, DATAFORMAT_STR));
- }
- /**
- * 将Date转换成字符串“yyyy-mm-dd hh:mm:ss”的字符串
- * @param date
- * @return
- */
- public static String dateToDateString(Date date)
- {
- return dateToDateString(date, DATATIMEF_STR);
- }
- /**
- * 将Date转换成formatStr格式的字符串
- * @param date
- * @param formatStr
- * @return
- */
- public static String dateToDateString(Date date, String formatStr)
- {
- DateFormat df = getDateFormat(formatStr);
- return df.format(date);
- }
- /**
- * 返回一个yyyy-MM-dd HH:mm:ss 形式的日期时间字符串中的HH:mm:ss
- * @param dateTime
- * @return
- */
- public static String getTimeString(String dateTime)
- {
- return getTimeString(dateTime, DATATIMEF_STR);
- }
- /**
- * 返回一个formatStr格式的日期时间字符串中的HH:mm:ss
- * @param dateTime
- * @param formatStr
- * @return
- */
- public static String getTimeString(String dateTime, String formatStr)
- {
- Date d = getDate(dateTime, formatStr);
- String s = dateToDateString(d);
- return s.substring(DATATIMEF_STR.indexOf('H'));
- }
- /**
- * 获取当前日期yyyy-MM-dd的形式
- * @return
- */
- public static String getCurDate()
- {
- //return dateToDateString(new Date(),DATAFORMAT_STR);
- return dateToDateString(Calendar.getInstance().getTime(), DATAFORMAT_STR);
- }
- /**
- * 获取当前日期yyyy年MM月dd日的形式
- * @return
- */
- public static String getCurZhCNDate()
- {
- return dateToDateString(new Date(), ZHCN_DATAFORMAT_STR);
- }
- /**
- * 获取当前日期时间yyyy-MM-dd HH:mm:ss的形式
- * @return
- */
- public static String getCurDateTime()
- {
- return dateToDateString(new Date(), DATATIMEF_STR);
- }
- /**
- * 获取当前日期时间yyyy年MM月dd日HH时mm分ss秒的形式
- * @return
- */
- public static String getCurZhCNDateTime()
- {
- return dateToDateString(new Date(), ZHCN_DATATIMEF_STR);
- }
- /**
- * 获取日期d的days天后的一个Date
- * @param d
- * @param days
- * @return
- */
- public static Date getInternalDateByDay(Date d, int days)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- now.add(Calendar.DATE, days);
- return now.getTime();
- }
- public static Date getInternalDateByMon(Date d, int months)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- now.add(Calendar.MONTH, months);
- return now.getTime();
- }
- public static Date getInternalDateByYear(Date d, int years)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- now.add(Calendar.YEAR, years);
- return now.getTime();
- }
- public static Date getInternalDateBySec(Date d, int sec)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- now.add(Calendar.SECOND, sec);
- return now.getTime();
- }
- public static Date getInternalDateByMin(Date d, int min)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- now.add(Calendar.MINUTE, min);
- return now.getTime();
- }
- public static Date getInternalDateByHour(Date d, int hours)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- now.add(Calendar.HOUR_OF_DAY, hours);
- return now.getTime();
- }
- /**
- * 根据一个日期字符串,返回日期格式,目前支持4种
- * 如果都不是,则返回null
- * @param DateString
- * @return
- */
- public static String getFormateStr(String DateString)
- {
- String patternStr1 = "[0-9]{4}-[0-9]{1,2}-[0-9]{1,2}"; //"yyyy-MM-dd"
- String patternStr2 = "[0-9]{4}-[0-9]{1,2}-[0-9]{1,2}\\s[0-9]{1,2}:[0-9]{1,2}:[0-9]{1,2}"; //"yyyy-MM-dd HH:mm:ss";
- String patternStr3 = "[0-9]{4}年[0-9]{1,2}月[0-9]{1,2}日";//"yyyy年MM月dd日"
- String patternStr4 = "[0-9]{4}年[0-9]{1,2}月[0-9]{1,2}日[0-9]{1,2}时[0-9]{1,2}分[0-9]{1,2}秒";//"yyyy年MM月dd日HH时mm分ss秒"
- Pattern p = Pattern.compile(patternStr1);
- Matcher m = p.matcher(DateString);
- boolean b = m.matches();
- if (b)
- return DATAFORMAT_STR;
- p = Pattern.compile(patternStr2);
- m = p.matcher(DateString);
- b = m.matches();
- if (b)
- return DATATIMEF_STR;
- p = Pattern.compile(patternStr3);
- m = p.matcher(DateString);
- b = m.matches();
- if (b)
- return ZHCN_DATAFORMAT_STR;
- p = Pattern.compile(patternStr4);
- m = p.matcher(DateString);
- b = m.matches();
- if (b)
- return ZHCN_DATATIMEF_STR;
- return null;
- }
- /**
- * 将一个"yyyy-MM-dd HH:mm:ss"字符串,转换成"yyyy年MM月dd日HH时mm分ss秒"的字符串
- * @param dateStr
- * @return
- */
- public static String getZhCNDateTime(String dateStr)
- {
- Date d = getDate(dateStr);
- return dateToDateString(d, ZHCN_DATATIMEF_STR);
- }
- /**
- * 将一个"yyyy-MM-dd"字符串,转换成"yyyy年MM月dd日"的字符串
- * @param dateStr
- * @return
- */
- public static String getZhCNDate(String dateStr)
- {
- Date d = getDate(dateStr, DATAFORMAT_STR);
- return dateToDateString(d, ZHCN_DATAFORMAT_STR);
- }
- /**
- * 将dateStr从fmtFrom转换到fmtTo的格式
- * @param dateStr
- * @param fmtFrom
- * @param fmtTo
- * @return
- */
- public static String getDateStr(String dateStr, String fmtFrom, String fmtTo)
- {
- Date d = getDate(dateStr, fmtFrom);
- return dateToDateString(d, fmtTo);
- }
- /**
- * 比较两个"yyyy-MM-dd HH:mm:ss"格式的日期,之间相差多少毫秒,time2-time1
- * @param time1
- * @param time2
- * @return
- */
- public static long compareDateStr(String time1, String time2)
- {
- Date d1 = getDate(time1);
- Date d2 = getDate(time2);
- return d2.getTime() - d1.getTime();
- }
- /**
- * 将小时数换算成返回以毫秒为单位的时间
- * @param hours
- * @return
- */
- public static long getMicroSec(BigDecimal hours)
- {
- BigDecimal bd;
- bd = hours.multiply(new BigDecimal(3600 * 1000));
- return bd.longValue();
- }
- /**
- * 获取Date中的分钟
- * @param d
- * @return
- */
- public static int getMin(Date d)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- return now.get(Calendar.MINUTE);
- }
- /**
- * 获取Date中的小时(24小时)
- * @param d
- * @return
- */
- public static int getHour(Date d)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- return now.get(Calendar.HOUR_OF_DAY);
- }
- /**
- * 获取Date中的秒
- * @param d
- * @return
- */
- public static int getSecond(Date d)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- return now.get(Calendar.SECOND);
- }
- /**
- * 获取xxxx-xx-xx的日
- * @param d
- * @return
- */
- public static int getDay(Date d)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- return now.get(Calendar.DAY_OF_MONTH);
- }
- /**
- * 获取月份,1-12月
- * @param d
- * @return
- */
- public static int getMonth(Date d)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- return now.get(Calendar.MONTH) + 1;
- }
- /**
- * 获取19xx,20xx形式的年
- * @param d
- * @return
- */
- public static int getYear(Date d)
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- now.setTime(d);
- return now.get(Calendar.YEAR);
- }
- /**
- * 得到d的上个月的年份+月份,如200505
- * @return
- */
- public static String getYearMonthOfLastMon(Date d)
- {
- Date newdate = getInternalDateByMon(d, -1);
- String year = String.valueOf(getYear(newdate));
- String month = String.valueOf(getMonth(newdate));
- return year + month;
- }
- /**
- * 得到当前日期的年和月如200509
- * @return String
- */
- public static String getCurYearMonth()
- {
- Calendar now = Calendar.getInstance(TimeZone.getDefault());
- String DATE_FORMAT = "yyyyMM";
- java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat(DATE_FORMAT);
- sdf.setTimeZone(TimeZone.getDefault());
- return (sdf.format(now.getTime()));
- }
- public static Date getNextMonth(String year, String month)
- {
- String datestr = year + "-" + month + "-01";
- Date date = getDate(datestr, DATAFORMAT_STR);
- return getInternalDateByMon(date, 1);
- }
- public static Date getLastMonth(String year, String month)
- {
- String datestr = year + "-" + month + "-01";
- Date date = getDate(datestr, DATAFORMAT_STR);
- return getInternalDateByMon(date, -1);
- }
- /**
- * 得到日期d,按照页面日期控件格式,如"2001-3-16"
- * @param d
- * @return
- */
- public static String getSingleNumDate(Date d)
- {
- return dateToDateString(d, DATAFORMAT_STR);
- }
- /**
- * 得到d半年前的日期,"yyyy-MM-dd"
- * @param d
- * @return
- */
- public static String getHalfYearBeforeStr(Date d)
- {
- return dateToDateString(getInternalDateByMon(d, -6), DATAFORMAT_STR);
- }
- /**
- * 得到当前日期D的月底的前/后若干天的时间,<0表示之前,>0表示之后
- * @param d
- * @param days
- * @return
- */
- public static String getInternalDateByLastDay(Date d, int days)
- {
- return dateToDateString(getInternalDateByDay(d, days), DATAFORMAT_STR);
- }
- /**
- * 日期中的年月日相加
- * @param field int 需要加的字段 年 月 日
- * @param amount int 加多少
- * @return String
- */
- public static String addDate(int field, int amount)
- {
- int temp = 0;
- if (field == 1)
- {
- temp = Calendar.YEAR;
- }
- if (field == 2)
- {
- temp = Calendar.MONTH;
- }
- if (field == 3)
- {
- temp = Calendar.DATE;
- }
- String Time = "";
- try
- {
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
- Calendar cal = Calendar.getInstance(TimeZone.getDefault());
- cal.add(temp, amount);
- Time = sdf.format(cal.getTime());
- return Time;
- }
- catch (Exception e)
- {
- e.printStackTrace();
- return null;
- }
- }
- /**
- * 获得系统当前月份的天数
- * @return
- */
- public static int getCurentMonthDay()
- {
- Date date = Calendar.getInstance().getTime();
- return getMonthDay(date);
- }
- /**
- * 获得指定日期月份的天数
- * @return
- */
- public static int getMonthDay(Date date)
- {
- Calendar c = Calendar.getInstance();
- c.setTime(date);
- return c.getActualMaximum(Calendar.DAY_OF_MONTH);
- }
- /**
- * 获得指定日期月份的天数 yyyy-mm-dd
- * @return
- */
- public static int getMonthDay(String date)
- {
- Date strDate = getDate(date, DATAFORMAT_STR);
- return getMonthDay(strDate);
- }
- public static String getStringDate(Calendar cal)
- {
- SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
- return format.format(cal.getTime());
- }
- /**
- * @param args
- */
- public static void main(String[] args)
- {
- // //System.out.print(DateUtil.getDate("04:04:04","HH:mm:ss"));
- // System.out.print("\n"+DateUtil.getCurZhCNDateTime());
- // System.out.print("\n"+getFormateStr(DateUtil.getCurDate()));
- // System.out.print("\n"+compareDateStr("1900-1-1 1:1:2","1900-1-1 1:1:3"));
- // System.out.print("\n"+getDay(new Date()));
- // System.out.print("\n"+getMonth(new Date()));
- // System.out.print("\n"+getYear(new Date()));
- // System.out.print("\n"+getMin(new Date()));
- //// System.out.print("\n"+new Date().getSeconds());
- /*Date d1 = new Date(2007,11,30);
- Date d2 = new Date(2007,12,1);
- if(d2.compareTo(d1)>0){
- System.out.println("d2大于d1");
- }else{
- System.out.println("d2小于d1");
- }*/
- System.out.println(addDate(1, 1));
- System.out.println(addDate(2, 1));
- System.out.println(addDate(3, 1));
- System.out.println(getYYYYMMDDHHMMSSDate(new Date()));
- System.out.println(getCurentMonthDay());
- }
- }
- </SPAN>