Java 日期工具类(日期,月份加减等)--转
- package util;
- import java.text.ParseException;
- import java.text.SimpleDateFormat;
- import java.util.Calendar;
- import java.util.Date;
- /***
- * 日期工具类
- *
- * @author damao
- *
- */
- public class DateAndTimeUtil {
- /***
- * 日期月份减一个月
- *
- * @param datetime
- * 日期(2014-11)
- * @return 2014-10
- */
- public static String dateFormat(String datetime) {
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM");
- Date date = null;
- try {
- date = sdf.parse(datetime);
- } catch (ParseException e) {
- e.printStackTrace();
- }
- Calendar cl = Calendar.getInstance();
- cl.setTime(date);
- cl.add(Calendar.MONTH, -1);
- date = cl.getTime();
- return sdf.format(date);
- }
- public static String dateFormat(Date date) {
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM");
- return sdf.format(date);
- }
- /****
- * 传入具体日期 ,返回具体日期减一个月。
- *
- * @param date
- * 日期(2014-04-20)
- * @return 2014-03-20
- * @throws ParseException
- */
- public static String subMonth(String date) throws ParseException {
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
- Date dt = sdf.parse(date);
- Calendar rightNow = Calendar.getInstance();
- rightNow.setTime(dt);
- rightNow.add(Calendar.MONTH, -1);
- Date dt1 = rightNow.getTime();
- String reStr = sdf.format(dt1);
- return reStr;
- }
- /****
- * 获取月末最后一天
- *
- * @param sDate
- * 2014-11-24
- * @return 30
- */
- private static String getMonthMaxDay(String sDate) {
- SimpleDateFormat sdf_full = new SimpleDateFormat("yyyy-MM-dd");
- Calendar cal = Calendar.getInstance();
- Date date = null;
- try {
- date = sdf_full.parse(sDate + "-01");
- } catch (ParseException e) {
- e.printStackTrace();
- }
- cal.setTime(date);
- int last = cal.getActualMaximum(Calendar.DATE);
- return String.valueOf(last);
- }
- // 判断是否是月末
- public static boolean isMonthEnd(Date date) {
- Calendar cal = Calendar.getInstance();
- cal.setTime(date);
- if (cal.get(Calendar.DATE) == cal
- .getActualMaximum(Calendar.DAY_OF_MONTH))
- return true;
- else
- return false;
- }
- /***
- * 日期减一天、加一天
- *
- * @param option
- * 传入类型 pro:日期减一天,next:日期加一天
- * @param _date
- * 2014-11-24
- * @return 减一天:2014-11-23或(加一天:2014-11-25)
- */
- public static String checkOption(String option, String _date) {
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
- Calendar cl = Calendar.getInstance();
- Date date = null;
- try {
- date = (Date) sdf.parse(_date);
- } catch (ParseException e) {
- e.printStackTrace();
- }
- cl.setTime(date);
- if ("pre".equals(option)) {
- // 时间减一天
- cl.add(Calendar.DAY_OF_MONTH, -1);
- } else if ("next".equals(option)) {
- // 时间加一天
- cl.add(Calendar.DAY_OF_YEAR, 1);
- } else {
- // do nothing
- }
- date = cl.getTime();
- return sdf.format(date);
- }
- /***
- * 判断日期是否为当前月, 是当前月返回当月最小日期和当月目前最大日期以及传入日期上月的最大日和最小日
- * 不是当前月返回传入月份的最大日和最小日以及传入日期上月的最大日和最小日
- *
- * @param date
- * 日期 例如:2014-11
- * @return String[] 开始日期,结束日期,上月开始日期,上月结束日期
- * @throws ParseException
- */
- public static String[] getNow_Pre_Date(String date) throws ParseException {
- String[] str_date = new String[4];
- Date now = new Date();
- SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM");
- SimpleDateFormat sdf_full = new SimpleDateFormat("yyyy-MM-dd");
- String stMonth = sdf.format(now);
- String stdate = "";// 开始日期
- String endate = "";// 结束日期
- String preDate_start = "";// 上月开始日期
- String preDate_end = "";// 上月结束日期
- // 当前月
- if (date.equals(stMonth)) {
- stdate = stMonth + "-01"; // 2014-11-01
- endate = sdf_full.format(now);// 2014-11-24
- preDate_start = subMonth(stdate);// 2014-10-01
- preDate_end = subMonth(endate);// 2014-10-24
- } else {
- // 非当前月
- String monthMaxDay = getMonthMaxDay(date);
- stdate = date + "-01";// 2014-10-01
- endate = date + "-" + monthMaxDay;// 2014-10-31
- preDate_start = subMonth(stdate);// 2014-09-01
- preDate_end = subMonth(endate);// 2014-09-30
- }
- str_date[0] = stdate;
- str_date[1] = endate;
- str_date[2] = preDate_start;
- str_date[3] = preDate_end;
- return str_date;
- }
- public static void main(String[] args) throws ParseException {
- /*
- * String a =DateAndTimeUtil.dateFormat(new Date());
- * System.out.println(a); String b =
- * DateAndTimeUtil.subMonth("2014-03-31"); System.out.println(b);
- * SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd"); Date
- * dt=sdf.parse("2014-03-31");
- * System.out.println(DateAndTimeUtil.isMonthEnd(dt));
- */
- String str = null;
- // str = DateAndTimeUtil.checkOption("next", "2014-11-30");
- // str = getMonthMaxDay("2014-11-24");
- // str = dateFormat("2014-11");
- str = getNow_Pre_Date("2014-10")[0];
- System.out.println(str);
- }
- }
Java 日期工具类(日期,月份加减等)--转的更多相关文章
- java工具类-日期工具类
1.获得时间戳 为了统一其他语言的如php和unix系统获取的时间戳是10位长度的,精确到秒. java时间戳长度是13位,精确到毫秒 我们获取时间戳需要相应处理. //获取当前时间戳,除以1000, ...
- java日期工具类DateUtil
一名优秀的程序员,不仅需要有着丰富解决问题的方案,还需要的便是代码的沉淀,这不仅有助于自己快速的开发程序,也有利于保证程序的健壮.那如何才能沉淀自己的”代码“呢?从自己编写util开始其实就是一个不错 ...
- java 日期工具类
import java.text.DateFormat; import java.text.ParseException; import java.text.SimpleDateFormat; imp ...
- 日期工具类 - DateUtil.java
日期工具类,提供对日期的格式化和转换方法.获取区间日期.指定日期.每月最后一天等. 源码如下:(点击下载 -DateUtil.java.commons-lang-2.6.jar ) import ja ...
- Java日期工具类,Java时间工具类,Java时间格式化
Java日期工具类,Java时间工具类,Java时间格式化 >>>>>>>>>>>>>>>>>&g ...
- java 日期工具类DateUtils
日期工具类DateUtils CreateTime--2017年5月27日08:48:00Author:Marydon DateUtils.java-对日期类的进一步封装 import java. ...
- java日期工具类DateUtil-续一
上篇文章中,我为大家分享了下DateUtil第一版源码,但就如同文章中所说,我发现了还存在不完善的地方,所以我又做了优化和扩展. 更新日志: 1.修正当字符串日期风格为MM-dd或yyyy-MM时,若 ...
- java日期工具类DateUtil-续二
该版本是一次较大的升级,农历相比公历复杂太多(真佩服古人的智慧),虽然有规律,但涉及到的取舍.近似的感念太多,况且本身的概念就已经很多了,我在网上也是查阅了很多的资料,虽然找到一些计算的方法,但都有些 ...
- Java获取上周,本周,本月,本年,开始结束时间 。日期工具类
由于获取日期经常会使用到,所有我自己写了一个工具类 1.基本上能用上的都写出来了,包括:1)获取当天的开始时间 2)获取当天的结束时间 3)获取昨天的开始时间 4)获取昨天的结束时间 5)获取明天的开 ...
随机推荐
- Springboot token令牌验证解决方案 在SpringBoot实现基于Token的用户身份验证
1.首先了解一下Token 1.token也称作令牌,由uid+time+sign[+固定参数]组成: uid: 用户唯一身份标识 time: 当前时间的时间戳 sign: 签名, 使用 hash/e ...
- ABP 基于DDD的.NET开发框架 学习(七)继承不同的service直接调用api的区别
1.IApplicationService->IBaseService->具体IXXXService 具体XXXService->BaseService,具体IXXXService ...
- ADO.NET 五(DataAdapter 与 DataSet)
在执行对表中数据的查询时还能将数据保存到 DataSet 中,但需要借助 DataAdapter 类来实现. 在实际应用中,DataAdapter 与 DataSet 是在查询操作中使用最多的类. 此 ...
- 智慧图携手DataPipeline,让实体商业更智慧!
近日,国内领先的实体商业数字化运营服务商智慧图携手DataPipeline,基于专业的数据集成与应用基础展开了合作. 未来DataPipeline将通过不断提升自身产品和服务实力,与智慧图一道致力于帮 ...
- live555的使用(转载)
Live555 是一个为流媒体提供解决方案的跨平台的C++开源项目,它实现了对标准流媒体传输协议如RTP/RTCP.RTSP.SIP等的支持.Live555实现 了对多种音视频编码格式的音视频数据的流 ...
- 【Bug】MQ消息与事务提交
项目联调期间,遇到个bug,涉及MQ消息传递和事务提交时间问题,简单记录下. 背景 审核服务(审核创建项目),点击审核通过,后台代码会在提交事务前发送MQ消息(该消息由项目管理服务消费),发送成功后, ...
- SQL Server 字段提取拼音首字母
目前工作中遇到一个情况,需要将SQL Server中的一个字段提取拼音的首字母,字段由汉字.英文.数字以及“-”构成,百度了一堆,找到如下方法,记录一下,以备后用! 首先建立一个函数 --生成拼音首码 ...
- Flask之flask-sqlalchemy
接下来基于这个Flask项目,我们要加入Flask-SQLAlchemy让项目变得生动起来 1.加入Flask-SQLAlchemy第三方组件 from flask import Flask # 导入 ...
- h5中hash的用法实例
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Mayor's posters (离散化线段树+对lazy的理解)
题目 题意: n(n<=10000) 个人依次贴海报,给出每张海报所贴的范围 li,ri(1<=li<=ri<=10000000) .求出最后还能看见多少张海报. 思路: 由于 ...