3hutool源码分析:DateUtil(时间工具类)-获取日期的各种内容

3hutool源码分析:DateUtil(时间工具类)-获取日期的各种内容,第1张

知其然,知其所以然

此博文的依据:hutool-565版本源码

获得年的部分

源码的DateTimeof(date)year()可拆解成两部分

第一部分,看代码很好理解,就是类型的转化

第二部分,

从代码跟下来,可以发现会走到 toCalendar()get(field)

toCalendar()会得到Calendar,这会就好理解可以获取年了。

不止可以获取年,还可以获取年,月,日,时,分,秒。详细介绍可以看这里:万字博文教你搞懂java源码的日期和时间相关用法

获得指定日期所属季度,从1开始计数

源码的DateTimeof(date)quarter()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,month()获取DateTime对应的月份,然后再做了一个简单计算。

getField方法上面有介绍了,这里就不水字了。

获得指定日期所属季度,返回的是季度枚举对象Quarter

源码的DateTimeof(date)quarterEnum()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,quarter()上面有源码分析,结论是获取 获得当前日期所属季度,从1开始计数

Quarterof(int)就是把对应的数值转为对应的枚举Quarter

获得月份,从0开始计数

源码的DateTimeof(date)month()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

获得月份,返回月份枚举对象Month

源码的DateTimeof(date)monthEnum()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,month()是获得月份,从0开始计数

Monthof(int)就是把对应的数值转为对应的枚举Month

获得指定日期是所在年份的第几周

此方法返回值与一周的第一天有关,比如:

2016年1月3日为周日,如果一周的第一天为周日,那这天是第二周(返回2)

如果一周的第一天为周一,那这天是第一周(返回1)

跨年的那个星期得到的结果总是1

源码的DateTimeof(date)weekOfYear()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

获得指定日期是所在月份的第几周

源码的DateTimeof(date)year()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

获得指定日期是这个日期所在月份的第几天

源码的DateTimeof(date)dayOfMonth()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

获得指定日期是这个日期所在年的第几天

源码的DateTimeof(date)dayOfYear()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

获得指定日期是星期几,1表示周日,2表示周一

源码的DateTimeof(date)dayOfWeek()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

获得指定日期是星期几

源码的DateTimeof(date)dayOfWeekEnum()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,dayOfWeek()是获得指定日期是星期几,1表示周日,2表示周一

Weekof(int)就是把对应的数值转为对应的枚举Week

获得指定日期的小时数部分

源码的DateTimeof(date)hour(is24HourClock)可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

is24HourClock DateFieldHOUR_OF_DAY : DateFieldHOUR :is24HourClock 是否24小时制

DateFieldHOUR_OF_DAY :小时,用于24小时制

DateFieldHOUR :小时,用于12小时制

获得指定日期的分钟数部分

例如:10:04:15250 =》 4

源码的DateTimeof(date)minute()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

获得指定日期的秒数部分

源码的DateTimeof(date)second()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

获得指定日期的毫秒数部分

源码的DateTimeof(date)millisecond()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

是否为上午

源码的DateTimeof(date)isAM()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

做了一个判断 CalendarAM == getField(DateFieldAM_PM)

是否为下午

源码的DateTimeof(date)isPM()可拆解成两部分

DateTimeof(date)上面有介绍了,这里就不水字了。

第二部分,getField方法上面有介绍了,这里就不水字了。

做了一个判断 CalendarPM== getField(DateFieldAM_PM)

返回今年

源码的year(date())可拆解成两部分

DateTimedate()

返回当前月份

源码的month(date())可拆解成两部分

DateTimedate()

返回当前月份

源码的monthEnum(date())可拆解成两部分

DateTimedate()

返回当前日期所在年份的第几周

源码的weekOfYear(date())可拆解成两部分

DateTimedate()

返回当前日期所在月份的第几周

源码的weekOfMonth(date())可拆解成两部分

DateTimedate()

返回当前日期是这个日期所在月份的第几天

源码的dayOfMonth(date())可拆解成两部分

DateTimedate()

返回当前日期是星期几

源码的dayOfWeek(date())可拆解成两部分

DateTimedate()

返回当前日期是星期几

源码的dayOfWeekEnum(date())可拆解成两部分

DateTimedate()

返回当前日期的小时数部分

源码的hour(date(), is24HourClock)可拆解成两部分

DateTimedate()

返回当前日期的分钟数部分

源码的minute(date())可拆解成两部分

DateTimedate()

返回当前日期的秒数部分

源码的second(date())可拆解成两部分

DateTimedate()

返回当前日期的毫秒数部分

源码的millisecond(date())可拆解成两部分

DateTimedate()

获得指定日期年份和季节

格式:[20131]表示2013年第一季度

源码的yearAndQuarter(calendar(date))可拆解成两部分

yearAndQuarter方法代码分析:

获取年份 calget(CalendarYEAR)

获取季度 calget(CalendarMONTH) / 3 + 1

然后通过StringBuilder拼接字符串

获得指定日期区间内的年份和季节

如上面代码所示,有个判空处理

然后,写了一个while循环,把符合条件的年份和季度存到LinkedHashSet里,存完一个年份和季度的字符串后,会给开始时间增加3个月,如果开始时间超出结束时间,让结束时间为开始时间,处理完后结束循环

转自: >

粗略计算,每年360天,每季度90天。每年中哪个月大哪个月小是固定的,大可事先获得。如果要计算从某日到某日共有多少天,用函数DAYS360(起之日,止之日),即可求得两个特定日期之间的天数。

你的意思是给一个时间跨度好比

2010/3/2-2015/05/06

然后输出 2010 2011 2012 2013 2014 2015 其他类似,是这个意思吗?

String format=new Format("yyyy"),format(new Data());

这样可以获得数字类型的年

Integer int =IntegerparsreInteger(format);

这样可以获得整形的年

之后就是进行循环读取即可。

以上就是关于3hutool源码分析:DateUtil(时间工具类)-获取日期的各种内容全部的内容,包括:3hutool源码分析:DateUtil(时间工具类)-获取日期的各种内容、获取本月、本季、本年第一天和最后一天等等sql(sql server)、在excel中如何自动获取季度天数等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/9551334.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存