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. Java-Redis Serializable序列化

    在Java中使用redis存储User对象时,进行JUnit测试时,控制台: 2019-06-24 16:56:45.520 INFO 27688 --- [ main] j.LocalContain ...

  2. python列表与字符串、元组的区别以及列表引用的方式

    一.字符串 字符串也可以用下标取值.切片.for循环.len()取长度以及 in 和 not in 来进行操作. 但字符串是不可变的,不能被更改.只能构造一个“新的”字符串来存取你想要修改后的数据. ...

  3. 一文搞懂 Java 中的枚举,写得非常好!

    知识点 概念 enum的全称为 enumeration, 是 JDK 1.5 中引入的新特性. 在Java中,被 enum关键字修饰的类型就是枚举类型.形式如下: enum Color { RED, ...

  4. Python学习笔记:运算符

    逻辑运算符: +   加 -    减 *    乘 /    除 %  取模-返回除法的余数 **  幂-返回x的y次方 //  整除 比较运算符: ==      等于-比较对象是否相等 !=  ...

  5. T100——查询 r类 报表开发流程

    报表开发流程:1.建立入口程序 如r类的作业:cxmr500步骤: azzi900中建立程序代号 azzi910中建立作业代号 设计器--规格--签出 设计器--程序--签出 adzp168(r.a) ...

  6. nginx-host

    下载nginx镜像 docker pull docker.io/nginx:latest 由于calico网络不支持http协议,所以即使你在iptables中配置了nat路由,将访问宿主机80端口的 ...

  7. CVPR2019目标检测方法进展综述

    CVPR2019目标检测方法进展综述 置顶 2019年03月20日 14:14:04 SIGAI_csdn 阅读数 5869更多 分类专栏: 机器学习 人工智能 AI SIGAI   版权声明:本文为 ...

  8. SSD性能测试

    Tested by CrystalDiskMark 7 * MB/s = 1,000,000 bytes/s [SATA/600 = 600,000,000 bytes/s]* KB = 1000 b ...

  9. C# 使用Emit实现动态AOP框架 进阶篇之异常处理

    目  录 C# 使用Emit实现动态AOP框架 (一) C# 使用Emit实现动态AOP框架 (二) C# 使用Emit实现动态AOP框架 (三) C# 使用Emit实现动态AOP框架 进阶篇之异常处 ...

  10. 关于mysql事务的几件小事

    零.MyISAM和InnoDB关于锁的区别 ①MyISAM默认用的是表级锁,不支持行级锁. ②InnoDB默认用的是行级锁,也支持表级锁. ③共享锁和排它锁的兼容性 |X|排它锁|共享锁| -|-|- ...