java时间操作工具类
import java.sql.Timestamp;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.ParsePosition;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.Locale;
import org.apache.commons.lang3.StringUtils;
import org.apache.commons.lang3.math.NumberUtils;
public class DateUtil {
public static final String DATETIME = "yyyy-MM-dd HH:mm:ss";
public static final String DATE = "yyyy-MM-dd";
public DateUtil() {
}
public static String datetimeToStr(Date date, String format) {
if (date == null) {
return null;
} else {
SimpleDateFormat sdf = new SimpleDateFormat(format);
return sdf.format(date);
}
}
public static String dateTimeToStr(Date date) {
return datetimeToStr(date, "yyyy-MM-dd HH:mm:ss");
}
public static String dateToStr(Date date) {
return datetimeToStr(date, "yyyy-MM-dd");
}
public static String dateToStr(Date date, String format) {
return datetimeToStr(date, format);
}
public static String getCurrentDate() {
return (new SimpleDateFormat("yyyy-MM-dd")).format(new Date());
}
public static String getCurrentDate(String format) {
return (new SimpleDateFormat(format)).format(new Date());
}
public static String getCurrentDatetime() {
return (new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")).format(new Date());
}
public static String getCurrentDatetime(String format) {
return (new SimpleDateFormat(format)).format(new Date());
}
public static int getCurrentTimeHashCode() {
return String.valueOf(System.currentTimeMillis()).hashCode();
}
public static Date getDateBegin(Date date) {
SimpleDateFormat ymdFormat = new SimpleDateFormat("yyyy-MM-dd");
if (date != null) {
try {
return DateFormat.getDateInstance(2, Locale.CHINA).parse(ymdFormat.format(date));
} catch (ParseException var3) {
System.err.println("DataFromat error");
}
}
return null;
}
public static Date getDateEnd(Date date) {
SimpleDateFormat ymdFormat = new SimpleDateFormat("yyyy-MM-dd");
if (date != null) {
try {
Date endDate = strToDate(ymdFormat.format(new Date(date.getTime() + 86400000L)));
endDate = new Date(endDate.getTime() - 1000L);
return endDate;
} catch (Exception var3) {
System.err.println("DataFromat error");
}
}
return null;
}
public static long getNow() {
return System.currentTimeMillis();
}
public static String getTime() {
Date d = new Date();
String re = datetimeToStr(d, "yyyyMMddHHmmssSSS");
return re;
}
public static String getTime(String format) {
Date d = new Date();
String re = datetimeToStr(d, format);
return re;
}
public static Date strToFormatDate(String date, String format) {
if (date == null) {
return null;
} else {
SimpleDateFormat sdf = new SimpleDateFormat(format);
return sdf.parse(date, new ParsePosition(0));
}
}
public static Date strToDate(String date) {
return strToFormatDate(date, "yyyy-MM-dd");
}
public static final Date strToDate(String dateStr, String format) {
return strToFormatDate(dateStr, format);
}
public static Date strToDateTime(String date) {
return strToFormatDate(date, "yyyy-MM-dd HH:mm:ss");
}
public static Date strToDateTime(String date, String format) {
return strToFormatDate(date, format);
}
public static Timestamp strToTimestamp(String str) throws Exception {
if (StringUtils.isEmpty(str)) {
throw new Exception("转换错误");
} else {
return str.trim().length() > 10 ? new Timestamp((new SimpleDateFormat("yyyy-MM-dd HH:mm:ss")).parse(str).getTime()) : new Timestamp((new SimpleDateFormat("yyyy-MM-dd")).parse(str).getTime());
}
}
public static Timestamp strToTimestamp(String sDate, String sFormat) throws ParseException {
SimpleDateFormat sdf = new SimpleDateFormat(sFormat);
Date t = sdf.parse(sDate);
return new Timestamp(t.getTime());
}
public static boolean validateExpireDate(long timeMillis, long expireTimeMillis) {
return getNow() - timeMillis > expireTimeMillis;
}
public static String getHHmmssSSS() {
Date d = new Date();
return getHHmmssSSS(d);
}
public static String getHHmmssSSS(Date d) {
int hh = Integer.valueOf(datetimeToStr(d, "HH"));
int mm = Integer.valueOf(datetimeToStr(d, "mm"));
int ss = Integer.valueOf(datetimeToStr(d, "ss"));
int sss = Integer.valueOf(datetimeToStr(d, "SSS"));
int time = 0;
if (hh != 0) {
time += hh * 60 * 60 * 1000;
}
if (mm != 0) {
time += mm * 60 * 1000;
}
if (ss != 0) {
time += ss * 1000;
}
if (sss != 0) {
time += sss;
}
String str;
for(str = String.valueOf(time); str.length() < 8; str = "0" + str) {
;
}
return str;
}
public static Date caculateDate(Date date, Integer count, int status) {
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
calendar.set(status, calendar.get(status) + count);
return calendar.getTime();
}
public static int caculateDaysNumber(int year, int month) {
Calendar cal = Calendar.getInstance();
cal.set(1, year);
cal.set(2, month - 1);
return cal.getActualMaximum(5);
}
public static Date caculateDateByNextBaseMonth(Date now, Integer month) {
Calendar cal = Calendar.getInstance();
cal.setTime(now);
cal.set(2, cal.get(2) + month + NumberUtils.INTEGER_ONE);
cal.set(5, NumberUtils.INTEGER_ZERO);
return cal.getTime();
}
public static Date caculateFinallyDatebyDateType(Date date, int dateType, int dateNumber) {
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
switch(dateType) {
case 1:
calendar.add(dateType, dateNumber + 1);
calendar.set(2, 0);
calendar.set(5, NumberUtils.INTEGER_ZERO);
break;
case 2:
calendar.add(2, dateNumber + 1);
calendar.set(5, NumberUtils.INTEGER_ZERO);
break;
case 3:
case 4:
default:
throw new RuntimeException("dateType value error");
case 5:
calendar.add(5, dateNumber);
}
return calendar.getTime();
}
public static int compareTime(String dateTime1, String dateTime2) {
if (!StringUtils.isEmpty(dateTime1) && !StringUtils.isEmpty(dateTime1)) {
DateFormat df = null;
if (dateTime1.length() == 10 && dateTime2.length() == 10) {
df = new SimpleDateFormat("yyyy-MM-dd");
} else {
if (dateTime1.length() != 19 || dateTime2.length() != 19) {
return 2;
}
df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
}
Calendar c1 = Calendar.getInstance();
Calendar c2 = Calendar.getInstance();
try {
c1.setTime(df.parse(dateTime1));
c2.setTime(df.parse(dateTime2));
} catch (ParseException var6) {
System.err.println("格式不正确");
}
int result = c1.compareTo(c2);
return result;
} else {
return 2;
}
}
public static void main(String[] args) {
Date now = new Date();
String nowStr = dateTimeToStr(now);
System.out.println(nowStr);
Date fDate = caculateFinallyDatebyDateType(now, 10, 3);
System.out.println(dateTimeToStr(fDate));
}
}
java时间操作工具类的更多相关文章
- java/javascript 时间操作工具类
一.java 时间操作工具类 import org.springframework.util.StringUtils; import java.text.ParseException; import ...
- Java日期工具类,Java时间工具类,Java时间格式化
Java日期工具类,Java时间工具类,Java时间格式化 >>>>>>>>>>>>>>>>>&g ...
- 小记Java时间工具类
小记Java时间工具类 废话不多说,这里主要记录以下几个工具 两个时间只差(Data) 获取时间的格式 格式化时间 返回String 两个时间只差(String) 获取两个时间之间的日期.月份.年份 ...
- JavaScript时间操作工具类
/** * 时间操作工具类 * * @author zwq * */ var TimeFrameUtil = { /** * 格式化日期 * @param date {Date} 日期 * @para ...
- docker 部署vsftpd服务、验证及java ftp操作工具类
docker部署vsftpd服务 新建ftp文件存储目录/home/ftp cd /home mkdir ftp 创建一个组,用于存放ftp用户 groupadd ftpgroups 创建ftp用户, ...
- Java时间处理类LocalDate和LocalDateTime常用方法
Java时间处理类LocalDate和LocalDateTime常用方法 https://blog.csdn.net/weixin_42579074/article/details/93721757
- Java时间转换类实现
Java时间类型非常的差,首先版本问题,本人使用java在Android平台开发.很多Data类的方法已经不提倡使用,一个时间,居然要使用Calendar.DateFormat等类共同编码,非常麻烦. ...
- 超详细的Java时间工具类
package com.td.util; import java.sql.Timestamp; import java.text.ParseException; import java.text.Pa ...
- JAVA文件操作工具类(读、增、删除、复制)
使用JAVA的JFinal框架 1.上传文件模型类UploadFile /** * Copyright (c) 2011-2017, James Zhan 詹波 (jfinal@126.com). * ...
随机推荐
- Class and Instance Variables In Ruby
https://github.com/unixc3t/mydoc/blob/master/blog/caiv.md
- 【百度之星2014~复赛)解题报告】The Query on the Tree
声明 笔者最近意外的发现 笔者的个人网站http://tiankonguse.com/ 的很多文章被其它网站转载,但是转载时未声明文章来源或参考自 http://tiankonguse.com/ 网站 ...
- Python爬虫-播报天气信息(生成exe文件)待续
#!/usr/bin/env python3 # -*- coding : utf-8 -*- '''1.从https://my.oschina.net/joanfen/blog/140364获取要播 ...
- 公司管理系列--80% of Your Culture is Your Founder(FaceBook)
80% of Your Culture is Your Founder When Molly Graham joined Facebook in 2008, the company still ...
- 深入理解JavaScript系列(49):Function模式(上篇)
介绍 本篇主要是介绍Function方面使用的一些技巧(上篇),利用Function特性可以编写出很多非常有意思的代码,本篇主要包括:回调模式.配置对象.返回函数.分布程序.柯里化(Currying) ...
- PHP学习9——MySQL数据库
主要内容: MySQL的启动 MySQL数据库操作 数据库表设计 创建和查看表 修改表结构 MySQL语句操作 数据库备份与恢复 PHP操作MySQL数据库 面向对象的数据库操作 MySQL数据库是目 ...
- Expression Blend实例中文教程(6) - 项目控件和用户交互控件快速入门
前文我们曾经描述过,微软把Silverlight控件大致分为三类: 第一类: Layout Controls(布局控件) 第二类: Item Controls (项目控件) 第三类: User Int ...
- 05.部分类 partial
namespace _06.部分类 { class Program { static void Main(string[] args) { } } /// <summary> /// 这个 ...
- PLSQL-12.0.7.1837注册码
product code: 4vkjwhfeh3ufnqnmpr9brvcuyujrx3n3le serial Number:226959 password: xs374ca LicenseNumbe ...
- 互联网轻量级框架SSM-查缺补漏第四天
简言:昨天第四章没看完,今天接着记吧. 4.5 typeHandler 类型转换器 顾名思义呀,就是将数据库中数据类型与Java数据类型做相互转换的处理器.在typeHandler中,分为jdbcTy ...