以前的博客“Java中的日期常用格式化”提到的都是当前日期的格式化,这篇博客写指定日期的格式化。当然类似于前一篇博客的内容就不多写了,写一些不一样的,如一个月的总天数,两个日期之间相隔的天数,字符串类型日期的格式化等。
废话不多说,上代码:
public class TimeTest { /** * 获取指定日期的年份 * @throws ParseException * **/ public static Integer year(String strDate){ int year = 0; SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Calendar calendar = new GregorianCalendar(); try{ Date date1 = sdf.parse(strDate); calendar.setTime(date1); //放入日期 year = calendar.get(Calendar.YEAR); }catch(ParseException e){ e.printStackTrace(); } return year; } /** * 获取指定日期的月份 * @throws ParseException * **/ public static Integer month(String strDate){ int month = 0; SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Calendar calendar = new GregorianCalendar(); try{ Date date1 = sdf.parse(strDate); calendar.setTime(date1); //放入日期 month = calendar.get(Calendar.MONTH)+1; }catch(ParseException e){ e.printStackTrace(); } return month; } /** * 获取指定日期的天 * @throws ParseException * **/ public static Integer day(String strDate){ int day = 0; SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Calendar calendar = new GregorianCalendar(); try{ Date date1 = sdf.parse(strDate); calendar.setTime(date1); //放入日期 day = calendar.get(Calendar.DAY_OF_MONTH); }catch(ParseException e){ e.printStackTrace(); } return day; } /** * 获取指定日期所在月份的天数 * @throws ParseException * **/ public static Integer getActualMaximum(String strDate){ int max = 0; SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM"); Calendar calendar = new GregorianCalendar(); try{ Date date1 = sdf.parse(strDate); calendar.setTime(date1); //放入日期 max = calendar.getActualMaximum(Calendar.DAY_OF_MONTH); }catch(ParseException e){ e.printStackTrace(); } return max; } /** * 将字符串类型的日期进行格式化,返回格式化之后字符串类型的日期 * @param String strDate:字符串格式的日期 * @return 字符串类型格式化后的日期,如:2016.06.05 * **/ public static String formatStringDateToYYYYMMDD(String strDate){ if (strDate == null) return ""; SimpleDateFormat sdf1 = new SimpleDateFormat("yyyy-MM-dd");// 实例化模板对象 SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy.MM.dd");// 实例化模板对象 Date d = null ; try{ d = sdf1.parse(strDate) ; // 将给定的字符串中的日期提取出来 }catch(Exception e){ // 如果提供的字符串格式有错误,则进行异常处理 e.printStackTrace() ;// 打印异常信息 e.printStackTrace(); } return sdf2.format(d);//按照规定格式进行格式化 } /** * 返回两个日期之间相差的天数,当date2>=date1时返回正数,否则返回负数 * @param date1:String类型 时间1 * @param date2:String类型 时间2 * @return days:返回date1和date2之间相差的天数 * */ public static int dateDiff(String date1, String date2){ SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Calendar calendar1 = new GregorianCalendar(); Calendar calendar2 = new GregorianCalendar(); try{ calendar1.setTime(sdf.parse(date1)); calendar2.setTime(sdf.parse(date2)); }catch(ParseException e){ e.printStackTrace(); } //设置时间为0时 calendar1.set(Calendar.HOUR_OF_DAY, 0); calendar1.set(Calendar.MINUTE, 0); calendar1.set(Calendar.SECOND, 0); calendar2.set(Calendar.HOUR_OF_DAY, 0); calendar2.set(Calendar.MINUTE, 0); calendar2.set(Calendar.SECOND, 0); //得到两个日期相差的天数 int days = ((int)(calendar2.getTime().getTime()/1000)-(int)(calendar1.getTime().getTime()/1000))/3600/24; return days; } /** * 返回指定年份月份的最后一天的时间 * @param strDate:要返回该月最后一天的字符串日期,必须包括年月 * */ public static String getLastDayEndForMonth(String strDate){ String time=""; int lastDay = getActualMaximum(strDate);//获取日期的所在月份的天数 int year = year(strDate);//获取年份 int month = month(strDate);//获取月份 time = year+"-"+month+"-"+lastDay+" 23:59:59"; SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); Date date = null; try{ date = df.parse(time); }catch(ParseException e){ e.printStackTrace(); } return df.format(date); } /** * 返回指定年份月份的第一天的时间 * @param strDate:要返回该月最后一天的字符串日期,必须包括年月 * */ public static String getFirstDayEndForMonth(String strDate){ String time=""; int year = year(strDate);//获取年份 int month = month(strDate);//获取月份 time = year+"-"+month+"-01 00:00:00.0"; SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); Date date = null; try{ date = df.parse(time); }catch(ParseException e){ e.printStackTrace(); } return df.format(date); } public static void main(String[] args) throws ParseException { System.out.println("年份:"+year("2016-06-16 00:00:00.000")); System.out.println("月份:"+month("2016-06-16 00:00:00.000")); System.out.println("天:"+day("2016-06-16 00:00:00.000")); System.out.println("6月的总天数:"+getActualMaximum("2016-06-16 00:00:00.000")); System.out.println("字符串类型的日期格式化:"+formatStringDateToYYYYMMDD("2016-06-16 00:00:00.000")); System.out.println("获取两个日期之间相差的天数:"+dateDiff("2016-06-16 00:00:00.000","2015-03-21 00:00:00.000")); System.out.println("指定年份月份的最后一天的时间:"+getLastDayEndForMonth("2016-06-16 00:00:00.000")); System.out.println("指定年份月份的第一天的时间:"+getFirstDayEndForMonth("2016-03-02 00:00:00.000")); } }
相关推荐
基于Springboot的实验报告系统源码数据库文档.zip
GEE训练教程——Landsat5、8和Sentinel-2、DEM和各2哦想指数下载
基于springboot智能健康饮食系统源码数据库文档.zip
基于SpringBoot的校园服务系统源码数据库文档.zip
内容概要: IXIA测试仪的基本配置.doc ixia测试仪基础使用示例.doc IxNetwork如何进行抓包回放-V1.0.pdf IxNetwork如何自定义报文-V2.0.pdf ixia构造ip分片方法.txt IxNetwork使用简介.pdf 适用人群:网络协议造包、打流相关的测试工程技术人员,想要学习的同学可以下载哈 使用场景:构造pcap包,打流 Ixia简介 IXIA使用的是Server-client模式,Server端在测试仪表的主机上,在开机后会随着主机内的操作系统的启动而自动启动,一般情况下不需要人为的手工启动。因此在通常不需要为主机配置专用的显示器和键盘。 client端包括两个测试软件: Ixia Explorer和ScriptMate。这两个软件一般安装在测试用计算机上,在仪表自带的主机中也有这两个软件。根据测试项目的不同来选择使用不同的软件。Ixia Explorer主要提供数据流的测试,针对设备的功能进行测试; ScriptMate提供各种性能测试窗口,针对设备的性能进行测试。 Auto:自动分配;
基于Python+Django花卉商城系统源码数据库文档.zip
Umi-OCR-main.zip
基于微信小程序开发的促销抽奖小工具源码,适用于初学者了解小程序开发过程以及简单抽奖工具的实现。
GEE训练教程——Landsat5、8和Sentinel-2、DEM和各2哦想指数下载
以下是一个关于Spring Boot设计的资源描述及项目源码的简要概述: Spring Boot设计资源描述 Spring Boot是一个为基于Spring的应用提供快速开发工具的框架,其设计旨在简化Spring应用的初始搭建和开发过程。以下是一些关键资源: Spring Boot官方文档:详细阐述了Spring Boot的核心特性、自动配置原理、起步依赖、内嵌式服务器等关键概念。这是学习和掌握Spring Boot设计的首选资源。 在线教程与视频:各大在线教育平台提供了丰富的Spring Boot教程和视频课程,从基础入门到高级应用,帮助开发者全面了解和掌握Spring Boot设计。 书籍与电子资料:许多技术书籍和在线电子资料深入讲解了Spring Boot的设计原理、最佳实践和项目案例,为开发者提供了宝贵的学习资源。 项目源码示例 以下是一个简单的Spring Boot项目源码示例,用于演示Spring Boot的基本结构和自动配置功能: java // 引入Spring Boot依赖 @SpringBootApplication public class MySpri
基于springboot美妆领域管理系统源码数据库文档.zip
tables-3.7.0+gpl-cp37-cp37m-win_amd64.whl
算法是计算机科学的核心,它们在解决各种问题时发挥着关键作用。一个好的算法不仅可以提高程序的效率,还可以简化复杂的问题。下面我将通过一个具体的例子——快速排序算法(Quick Sort)——来展示算法的实现过程,包括资源描述和项目源码。 ### 快速排序算法简介 快速排序是一种高效的排序算法,采用分治法的思想。其基本步骤如下: 1. 从数列中挑出一个元素,称为“基准”(pivot)。 2. 重新排序数列,所有比基准值小的元素放到基准前面,所有比基准值大的元素放到基准后面(相同的数可以到任一边)。在这个分割结束之后,该基准就处于数列的中间位置。这个称为分割(partition)操作。 3. 递归地(recursive)把小于基准值的子数列和大于基准值的子数列排序。 ### 资源描述 快速排序算法因其高效性和简洁性,在实际应用中非常受欢迎。它的时间复杂度平均为 O(n log n),最坏情况下为 O(n^2),但这种情况很少发生。快速排序的空间复杂度为 O(log n),因为它使用了递归来实现。 快速排序的一个典型应用场景是在数据库系统中对大量数据进行排序。由于它的高效性,快速排序
基于springboot农场投入品运营线上管理系统源码数据库文档.zip
基于springboot个性化影院推荐系统源码数据库文档.zip
linux基础进阶笔记,配套视频:https://www.bilibili.com/list/474327672?sid=4493093&spm_id_from=333.999.0.0&desc=1
小程序 微信自动抢红包动态库.zip程序资源学习资料参考
小程序 iOS版微信抢红包插件(支持后台抢红包).zip
经典-FPGA时序约束教程
基于springboot的智慧点餐系统源码数据库文档.zip