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个月,如果开始时间超出结束时间,让结束时间为开始时间,处理完后结束循环

选中表格,点击上方菜单栏上的“数据”。

2

/5

在数据菜单下的获取和转换命令组区域点击“从表格”,在d出的创建表对话框中勾选 “表包含标题”,点击确定按钮,将日期加载到PowerQuery编辑器。

3

/5

在编辑器中的添加列菜单下点击“自定义列”。

4

/5

在d出的自定义列对话框中“新列名”下面输入列标题,在公式下面输入=DateDay(),在可用列下面双击日期所在列的列标题将其引用到参数中,点击确定按钮,即可批量提取出日期中的“天”。

5

/5

提取完成后点击主页菜单下的“关闭并上载”,即可加载回Excel工作表中。

以上就是关于3hutool源码分析:DateUtil(时间工具类)-获取日期的各种内容全部的内容,包括:3hutool源码分析:DateUtil(时间工具类)-获取日期的各种内容、excel如何通过powerquery生成某一区间内所有日期、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存