import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
/**
* 描述:公共日期工具类
*/
public class DateUtils { public static String DATE_FORMAT = "yyyy-MM-dd"; public static String DATE_TIME_FORMAT = "yyyy-MM-dd HH:mm:ss"; public static String DATE_FORMAT_CHINESE = "yyyy年M月d日"; /**
* 获取当前日期
*
*
* @return
*
*/
public static String getCurrentDate() {
String datestr = null;
SimpleDateFormat df = new SimpleDateFormat(DateUtils.DATE_FORMAT);
datestr = df.format(new Date());
return datestr;
} /**
* 获取当前日期时间
*
*
* @return
*
*/
public static String getCurrentDateTime() {
String datestr = null;
SimpleDateFormat df = new SimpleDateFormat(DateUtils.DATE_TIME_FORMAT);
datestr = df.format(new Date());
return datestr;
} /**
* 获取当前日期时间
*
*
* @return
*
*/
public static String getCurrentDateTime(String Dateformat) {
String datestr = null;
SimpleDateFormat df = new SimpleDateFormat(Dateformat);
datestr = df.format(new Date());
return datestr;
} public static String dateToDateTime(Date date) {
String datestr = null;
SimpleDateFormat df = new SimpleDateFormat(DateUtils.DATE_TIME_FORMAT);
datestr = df.format(date);
return datestr;
}
/**
* 将字符串日期转换为日期格式
*
*
* @param datestr
* @return
*
*/
public static Date stringToDate(String datestr) { if(datestr ==null ||datestr.equals("")){
return null;
}
Date date = new Date();
SimpleDateFormat df = new SimpleDateFormat(DateUtils.DATE_FORMAT);
try {
date = df.parse(datestr);
} catch (ParseException e) {
date=DateUtils.stringToDate(datestr,"yyyyMMdd");
}
return date;
} /**
* 将字符串日期转换为日期格式
* 自定義格式
*
* @param datestr
* @return
*
*/
public static Date stringToDate(String datestr, String dateformat) {
Date date = new Date();
SimpleDateFormat df = new SimpleDateFormat(dateformat);
try {
date = df.parse(datestr);
} catch (ParseException e) {
e.printStackTrace();
}
return date;
} /**
* 将日期格式日期转换为字符串格式
*
*
* @param date
* @return
*
*/
public static String dateToString(Date date) {
String datestr = null;
SimpleDateFormat df = new SimpleDateFormat(DateUtils.DATE_FORMAT);
datestr = df.format(date);
return datestr;
} /**
* 将日期格式日期转换为字符串格式 自定義格式
*
* @param date
* @param dateformat
* @return
*/
public static String dateToString(Date date, String dateformat) {
String datestr = null;
SimpleDateFormat df = new SimpleDateFormat(dateformat);
datestr = df.format(date);
return datestr;
} /**
* 获取日期的DAY值
*
*
* @param date
* 输入日期
* @return
*
*/
public static int getDayOfDate(Date date) {
int d = 0;
Calendar cd = Calendar.getInstance();
cd.setTime(date);
d = cd.get(Calendar.DAY_OF_MONTH);
return d;
} /**
* 获取日期的MONTH值
*
*
* @param date
* 输入日期
* @return
*
*/
public static int getMonthOfDate(Date date) {
int m = 0;
Calendar cd = Calendar.getInstance();
cd.setTime(date);
m = cd.get(Calendar.MONTH) + 1;
return m;
} /**
* 获取日期的YEAR值
*
*
* @param date
* 输入日期
* @return
*
*/
public static int getYearOfDate(Date date) {
int y = 0;
Calendar cd = Calendar.getInstance();
cd.setTime(date);
y = cd.get(Calendar.YEAR);
return y;
} /**
* 获取星期几
*
*
* @param date
* 输入日期
* @return
*
*/
public static int getWeekOfDate(Date date) {
int wd = 0;
Calendar cd = Calendar.getInstance();
cd.setTime(date);
wd = cd.get(Calendar.DAY_OF_WEEK) - 1;
return wd;
} /**
* 获取输入日期的当月第一天
*
*
* @param date
* 输入日期
* @return
*
*/
public static Date getFirstDayOfMonth(Date date) {
Calendar cd = Calendar.getInstance();
cd.setTime(date);
cd.set(Calendar.DAY_OF_MONTH, 1);
return cd.getTime();
} /**
* 获得输入日期的当月最后一天
*
* @param date
*/
public static Date getLastDayOfMonth(Date date) {
return DateUtils.addDay(DateUtils.getFirstDayOfMonth(DateUtils.addMonth(date, 1)), -1);
} /**
* 判断是否是闰年
*
*
* @param date
* 输入日期
* @return 是true 否false
*
*/
public static boolean isLeapYEAR(Date date) { Calendar cd = Calendar.getInstance();
cd.setTime(date);
int year = cd.get(Calendar.YEAR); if (year % 4 == 0 && year % 100 != 0 | year % 400 == 0) {
return true;
} else {
return false;
}
} /**
* 根据整型数表示的年月日,生成日期类型格式
*
* @param year
* 年
* @param month
* 月
* @param day
* 日
* @return
*
*/
public static Date getDateByYMD(int year, int month, int day) {
Calendar cd = Calendar.getInstance();
cd.set(year, month-1, day);
return cd.getTime();
} /**
* 获取年周期对应日
*
* @param date
* 输入日期
* @param iyear
* 年数 負數表示之前
* @return
*
*/
public static Date getYearCycleOfDate(Date date, int iyear) {
Calendar cd = Calendar.getInstance();
cd.setTime(date); cd.add(Calendar.YEAR, iyear); return cd.getTime();
} /**
* 获取月周期对应日
*
* @param date
* 输入日期
* @param i
* @return
*
*/
public static Date getMonthCycleOfDate(Date date, int i) {
Calendar cd = Calendar.getInstance();
cd.setTime(date); cd.add(Calendar.MONTH, i); return cd.getTime();
} /**
* 计算 fromDate 到 toDate 相差多少年
*
* @param fromDate
* @param toDate
* @return 年数
*
*/
public static int getYearByMinusDate(Date fromDate, Date toDate) {
Calendar df=Calendar.getInstance();
df.setTime(fromDate); Calendar dt=Calendar.getInstance();
dt.setTime(toDate); return dt.get(Calendar.YEAR)-df.get(Calendar.YEAR);
} /**
* 计算 fromDate 到 toDate 相差多少个月
*
* @param fromDate
* @param toDate
* @return 月数
*
*/
public static int getMonthByMinusDate(Date fromDate, Date toDate) {
Calendar df=Calendar.getInstance();
df.setTime(fromDate); Calendar dt=Calendar.getInstance();
dt.setTime(toDate); return dt.get(Calendar.YEAR)*12+dt.get(Calendar.MONTH)-
(df.get(Calendar.YEAR)*12+df.get(Calendar.MONTH));
} /**
* 计算 fromDate 到 toDate 相差多少天
*
* @param fromDate
* @param toDate
* @return 天数
*
*/
public static long getDayByMinusDate(Object fromDate, Object toDate) { Date f=DateUtils.chgObject(fromDate); Date t=DateUtils.chgObject(toDate); long fd=f.getTime();
long td=t.getTime(); return (td-fd)/(24L * 60L * 60L * 1000L);
} /**
* 计算年龄
*
* @param birthday
* 生日日期
* @param calcDate
* 要计算的日期点
* @return
*
*/
public static int calcAge(Date birthday, Date calcDate) { int cYear=DateUtils.getYearOfDate(calcDate);
int cMonth=DateUtils.getMonthOfDate(calcDate);
int cDay=DateUtils.getDayOfDate(calcDate);
int bYear=DateUtils.getYearOfDate(birthday);
int bMonth=DateUtils.getMonthOfDate(birthday);
int bDay=DateUtils.getDayOfDate(birthday); if(cMonth>bMonth||(cMonth==bMonth&&cDay>bDay)){
return cYear-bYear;
}else{
return cYear-1-bYear;
}
} /**
* 从身份证中获取出生日期
*
* @param idno
* 身份证号码
* @return
*
*/
public static String getBirthDayFromIDCard(String idno) {
Calendar cd = Calendar.getInstance();
if (idno.length() == 15) {
cd.set(Calendar.YEAR, Integer.valueOf("19" + idno.substring(6, 8))
.intValue());
cd.set(Calendar.MONTH, Integer.valueOf(idno.substring(8, 10))
.intValue() - 1);
cd.set(Calendar.DAY_OF_MONTH,
Integer.valueOf(idno.substring(10, 12)).intValue());
} else if (idno.length() == 18) {
cd.set(Calendar.YEAR, Integer.valueOf(idno.substring(6, 10))
.intValue());
cd.set(Calendar.MONTH, Integer.valueOf(idno.substring(10, 12))
.intValue() - 1);
cd.set(Calendar.DAY_OF_MONTH,
Integer.valueOf(idno.substring(12, 14)).intValue());
}
return DateUtils.dateToString(cd.getTime());
} /**
* 在输入日期上增加(+)或减去(-)天数
*
* @param date
* 输入日期
* @param imonth
* 要增加或减少的天数
*/
public static Date addDay(Date date, int iday) {
Calendar cd = Calendar.getInstance(); cd.setTime(date); cd.add(Calendar.DAY_OF_MONTH, iday); return cd.getTime();
} /**
* 在输入日期上增加(+)或减去(-)月份
*
* @param date
* 输入日期
* @param imonth
* 要增加或减少的月分数
*/
public static Date addMonth(Date date, int imonth) {
Calendar cd = Calendar.getInstance(); cd.setTime(date); cd.add(Calendar.MONTH, imonth); return cd.getTime();
} /**
* 在输入日期上增加(+)或减去(-)年份
*
* @param date
* 输入日期
* @param imonth
* 要增加或减少的年数
*/
public static Date addYear(Date date, int iyear) {
Calendar cd = Calendar.getInstance(); cd.setTime(date); cd.add(Calendar.YEAR, iyear); return cd.getTime();
} /**
* 將OBJECT類型轉換為Date
* @param date
* @return
*/
public static Date chgObject(Object date){ if(date!=null&&date instanceof Date){
return (Date)date;
} if(date!=null&&date instanceof String){
return DateUtils.stringToDate((String)date);
} return null; } public static long getAgeByBirthday(String date){ Date birthday = stringToDate(date, "yyyy-MM-dd");
long sec = new Date().getTime() - birthday.getTime(); long age = sec/(1000*60*60*24)/365; return age;
} /**
* @param args
*/
public static void main(String[] args) {
//String temp = DateUtil.dateToString(getLastDayOfMonth(new Date()),
/// DateUtil.DATE_FORMAT_CHINESE);
//String s=DateUtil.dateToString(DateUtil.addDay(DateUtil.addYear(new Date(),1),-1)); long s=DateUtils.getDayByMinusDate("2012-01-01", "2012-12-31");
System.err.println(s); } }

Java-DateUtils工具类的更多相关文章

  1. 小记Java时间工具类

    小记Java时间工具类 废话不多说,这里主要记录以下几个工具 两个时间只差(Data) 获取时间的格式 格式化时间 返回String 两个时间只差(String) 获取两个时间之间的日期.月份.年份 ...

  2. Java Properties工具类详解

    1.Java Properties工具类位于java.util.Properties,该工具类的使用极其简单方便.首先该类是继承自 Hashtable<Object,Object> 这就奠 ...

  3. Java json工具类,jackson工具类,ObjectMapper工具类

    Java json工具类,jackson工具类,ObjectMapper工具类 >>>>>>>>>>>>>>> ...

  4. Java日期工具类,Java时间工具类,Java时间格式化

    Java日期工具类,Java时间工具类,Java时间格式化 >>>>>>>>>>>>>>>>>&g ...

  5. Java并发工具类 - CountDownLatch

    Java并发工具类 - CountDownLatch 1.简介 CountDownLatch是Java1.5之后引入的Java并发工具类,放在java.util.concurrent包下面 http: ...

  6. MinerUtil.java 爬虫工具类

    MinerUtil.java 爬虫工具类 package com.iteye.injavawetrust.miner; import java.io.File; import java.io.File ...

  7. MinerDB.java 数据库工具类

    MinerDB.java 数据库工具类 package com.iteye.injavawetrust.miner; import java.sql.Connection; import java.s ...

  8. Java Cookie工具类,Java CookieUtils 工具类,Java如何增加Cookie

    Java Cookie工具类,Java CookieUtils 工具类,Java如何增加Cookie >>>>>>>>>>>>& ...

  9. UrlUtils工具类,Java URL工具类,Java URL链接工具类

    UrlUtils工具类,Java URL工具类,Java URL链接工具类 >>>>>>>>>>>>>>>&g ...

  10. java日期工具类DateUtil-续一

    上篇文章中,我为大家分享了下DateUtil第一版源码,但就如同文章中所说,我发现了还存在不完善的地方,所以我又做了优化和扩展. 更新日志: 1.修正当字符串日期风格为MM-dd或yyyy-MM时,若 ...

随机推荐

  1. Mysql事件调度器学习

    在cassandra数据库中,有一个叫做TTL的功能,即插入一条记录时,可以指定某一字段对应的TTL值,比如30s,那么当TTL到达30s后该条记录就会被自动删除.目前MySQL并未直接提供TTL的功 ...

  2. [转帖]加强Linux服务器安全的20项建议

    加强Linux服务器安全的20项建议 2017-10-19 22:15:01作者:Linux编辑稿源:系统极客 https://ywnz.com/linuxyffq/99.html 一般情况下用 Li ...

  3. 【Python】【基础知识】【内置函数】【print的使用方法】

    原英文帮助文档: print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False) Print objects to the text ...

  4. Kafka如何实现每秒上百万的高并发写入

    Kafka是高吞吐低延迟的高并发.高性能的消息中间件,在大数据领域有极为广泛的运用.配置良好的Kafka集群甚至可以做到每秒几十万.上百万的超高并发写入. 那么Kafka到底是如何做到这么高的吞吐量和 ...

  5. SQLite基础-8.子句(二)

    目录 SQLite子句(二) 1. GROUP BY子句 2. HAVING子句 3. LIMIT 子句 4. IF EXISTS 和 IF NOT EXISTS 子句 SQLite子句(二) 1. ...

  6. 谈谈Java中的集合list、set、map之间的区别

    参考文献:https://www.cnblogs.com/IvesHe/p/6108933.html 我这里只总结其区别,具体的说明,请查看参考文献,讲的很详细. A.list接口,实现子类有:arr ...

  7. 终于有人把“TCC分布式事务”实现原理讲明白了

    所以这篇文章,就用大白话+手工绘图,并结合一个电商系统的案例实践,来给大家讲清楚到底什么是 TCC 分布式事务. 首先说一下,这里可能会牵扯到一些 Spring Cloud 的原理,如果有不太清楚的同 ...

  8. MySQL8在CentOS7上的安装

    Install_CentOS7_MySQL8_binary.sh #!/bin/bash MySQL_Package=mysql-8.0.16-linux-glibc2.12-x86_64.tar.x ...

  9. C/S软件方案

    互联网时代客户端软件的一些方案 纯Native开发, C++/C#/duilib+C++(Windows), Objective-c(Mac) Qt(Windows/Mac) NW.js/Electr ...

  10. 修改git默认的编辑器nano为vim的方法

    git默认的编辑器是nano,使用起来不易操作,下面介绍两种方法将git默认的编辑器修改为vim.  git config --global core.editor vim .git/config文件 ...