Java日期时间API系列36

Wesley13
• 阅读 403

  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:

时辰

时间

24时制

子时

深夜 11:00 - 凌晨 01:00

23:00 - 01 :00

丑时

上午 01:00 - 上午 03:00

01:00 - 03 :00

寅时

上午 03:00 - 上午 05:00

03:00 - 05 :00

卯时

上午 05:00 - 上午 07:00

05:00 - 07 :00

辰时

上午 07:00 - 上午 09:00

07:00 - 09 :00

巳时

上午 09:00 - 上午 11:00

09:00 - 11:00

午时

上午 11:00 - 下午 01:00

11:00 - 13:00

未时

下午 01:00 - 下午 03:00

13:00 - 15:00

申时

下午 03:00 - 下午 05:00

15:00 - 17:00

酉时

下午 05:00 - 下午 07:00

17:00 - 19:00

戌时

下午 07:00 - 下午 09:00

19:00 - 21:00

亥时

下午 09:00 - 下午 11:00

21:00 - 23:00

二十四小时和十二时辰对照表来源:http://114.xixik.com/shichen/

下面Java中如何计算十二时辰

1.十二时辰枚举

package com.xkzhangsan.time.enums; import java.time.LocalTime; import java.util.Date; import java.util.Objects; import com.xkzhangsan.time.constants.Constant; import com.xkzhangsan.time.converter.DateTimeConverterUtil; /** * 十二时辰枚举,包含英文全称,中文全称,时间范围 * * @author xkzhangsan * @date 2020年08-01 */ public enum TwelveTwoEnum {

ZISHI(1, "子时", "23:00:00", "01:00:00"),
CHOUSHI(2, "丑时", "01:00:00", "03:00:00"),
YINSHI(3, "寅时", "03:00:00", "05:00:00"),
MAOSHI(4, "卯辰", "05:00:00", "07:00:00"),
CHENSHI(5, "辰时", "07:00:00", "09:00:00"),
SISHI(6, "巳时", "09:00:00", "11:00:00"),
WUSHI(7, "午时", "11:00:00", "13:00:00"), 
WEISHI(8, "未时", "13:00:00", "15:00:00"),
SHENSHI(9, "申时", "15:00:00", "17:00:00"),
YOUSHI(10, "酉时", "17:00:00", "19:00:00"),
XUSHI(11, "戌时", "19:00:00", "21:00:00"),
HAISHI(12, "亥时", "21:00:00", "23:00:00"),; /\*\* \* 序号 \*/
private int code; /\*\* \* 中文名称 \*/
private String nameCn; /\*\* \* 开始时间 \*/
private String startTime; /\*\* \* 结束时间 \*/
private String endTime; private TwelveTwoEnum(int code, String nameCn, String startTime, String endTime) { this.code = code; this.nameCn = nameCn; this.startTime = startTime; this.endTime = endTime;
} /\*\* \* 根据时间查询时辰名称枚举
 \* @param localTime
 \* @return TwelveHoursEnum \*/
public static TwelveTwoEnum getTwelveHoursEnum(LocalTime localTime){
    Objects.requireNonNull(localTime, "localTime"); for(TwelveTwoEnum twelveHours : TwelveTwoEnum.values()){
        LocalTime timeStart \= LocalTime.parse(twelveHours.getStartTime());
        LocalTime timeEnd \= LocalTime.parse(twelveHours.getEndTime()); //子时,特殊计算
        if(isZiShi(localTime, timeStart, timeEnd)){ return TwelveTwoEnum.ZISHI;
        } if (isBetween(localTime, timeStart, timeEnd)) { return twelveHours;
        }
    } return null;
} /\*\* \* 时间区间判断
 \* @param localTime
 \* @param timeStart
 \* @param timeEnd
 \* @return 在区间 true,不在 false \*/
private static boolean isBetween(LocalTime localTime, LocalTime timeStart, LocalTime timeEnd) { return localTime.equals(timeStart) || (localTime.isAfter(timeStart) && localTime.isBefore(timeEnd));
} /\*\* \* 是否子时
 \* @param localTime
 \* @param timeStart
 \* @param timeEnd
 \* @return 是 true, 否 false \*/
private static boolean isZiShi(LocalTime localTime, LocalTime timeStart, LocalTime timeEnd) { //23点,0点
    if(Constant.TWENTYTHREECLOCK.equals(localTime) || LocalTime.MIDNIGHT.equals(localTime)){ return true;
    } //23-0点
    if(localTime.isAfter(Constant.TWENTYTHREECLOCK) && localTime.isBefore(LocalTime.MIDNIGHT)){ return true;
    } //0-1点
    if(localTime.isAfter(LocalTime.MIDNIGHT) && localTime.isBefore(Constant.ONECLOCK)){ return true;
    } return false;
} /\*\* \* 根据时间查询时辰名称
 \* @param localTime
 \* @return String \*/
public static String getNameCn(LocalTime localTime){
    TwelveTwoEnum twelveHours \= getTwelveHoursEnum(localTime); return twelveHours != null ? twelveHours.getNameCn() : null;
} /\*\* \* 根据时间查询时辰名称
 \* @param date
 \* @return String \*/
public static String getNameCn(Date date){ return getNameCn(DateTimeConverterUtil.toLocalTime(date));
} public int getCode() { return code;
} public String getNameCn() { return nameCn;
} public String getStartTime() { return startTime;
} public String getEndTime() { return endTime;
}

}

通过上面代码可以看出,LocalTime 直接解析起始时间,对比当前输入时间,得到对应的十二时辰。

LocalTime timeStart = LocalTime.parse(twelveHours.getStartTime());

2.测试代码

/** * 十二时辰测试 */ @Test public void getTwelveHoursTest(){ LocalTime localTime = LocalTime.of(23,0,0); Assert.assertEquals("子时", TwelveTwoEnum.getNameCn(localTime));

    Date date \= DateTimeCalculatorUtil.getDate(2020, 8, 1, 0,30,0);
    Assert.assertEquals("子时", TwelveTwoEnum.getNameCn(date));
}

源代码地址:https://github.com/xkzhangsan/xk-time

点赞
收藏
评论区
推荐文章
技术小男生 技术小男生
2个月前
linux环境jdk环境变量配置
1:编辑系统配置文件vi/etc/profile2:按字母键i进入编辑模式,在最底部添加内容:JAVAHOME/opt/jdk1.8.0152CLASSPATH.:$JAVAHOME/lib/dt.jar:$JAVAHOME/lib/tools.jarPATH$JAVAHOME/bin:$PATH3:生效配置
光头强的博客 光头强的博客
2个月前
Java面向对象试题
1、请创建一个Animal动物类,要求有方法eat()方法,方法输出一条语句“吃东西”。创建一个接口A,接口里有一个抽象方法fly()。创建一个Bird类继承Animal类并实现接口A里的方法输出一条有语句“鸟儿飞翔”,重写eat()方法输出一条语句“鸟儿吃虫”。在Test类中向上转型创建b对象,调用eat方法。然后向下转型调用eat()方
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
1年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
Wesley13 Wesley13
1年前
Java爬虫之JSoup使用教程
title:Java爬虫之JSoup使用教程date:201812248:00:000800update:201812248:00:000800author:mecover:https://imgblog.csdnimg.cn/20181224144920712(https://www.oschin
Stella981 Stella981
1年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Stella981 Stella981
1年前
Docker 部署SpringBoot项目不香吗?
  公众号改版后文章乱序推荐,希望你可以点击上方“Java进阶架构师”,点击右上角,将我们设为★“星标”!这样才不会错过每日进阶架构文章呀。  !(http://dingyue.ws.126.net/2020/0920/b00fbfc7j00qgy5xy002kd200qo00hsg00it00cj.jpg)  2
Wesley13 Wesley13
1年前
ASCII
ASCII控制字符二进制十进制十六进制缩写可以显示的表示法名称/意义0000 0000000NUL␀空字符(Null)0000 0001101SOH␁标题开始0000 0010202STX␂本文开始0000 0011303ETX␃本
Wesley13 Wesley13
1年前
PHP中的NOW()函数
是否有一个PHP函数以与MySQL函数NOW()相同的格式返回日期和时间?我知道如何使用date()做到这一点,但是我问是否有一个仅用于此的函数。例如,返回:2009120100:00:001楼使用此功能:functiongetDatetimeNow(){
Wesley13 Wesley13
1年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_