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

 
 
时辰 时间 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

Java日期时间API系列36-----Jdk8中java.time包中的新的日期时间API类应用,使用LocalTime计算十二时辰。的更多相关文章

  1. 在swt中获取jar包中的文件 uri is not hierarchical

    uri is not hierarchical 学习了:http://blog.csdn.net/zdsdiablo/article/details/1519719 在swt中获取jar包中的文件: ...

  2. API接口自动化之3 同一个war包中多个接口做自动化测试

    同一个war包中多个接口做自动化测试 一个接口用一个测试类,每个测试用例如下,比如下面是4个测试用例,每个详细的测试用例中含有请求入参,返回体校验,以此来判断每条测试用例是否通过 一个war包中,若含 ...

  3. Andriod项目开发实战(1)——如何在Eclipse中的一个包下建新包

    最开始是想将各个类分门别类地存放在不同的包中,所以想在项目源码包中新建几个不同功能的包eg:utils.model.receiver等,最后的结果应该是下图左边这样的:   很明显建立项目后的架构是上 ...

  4. Mac 如何导出ipa文件中Assets.car包中的切图

    在之前 获取 AppStore 中 应用 的 IPA 包文件(Mac OS 13+)中获取到应用的 IPA 包,可以取出应用的部分图片(如 Logo),如果项目工程中把图片添加到 Assets.xca ...

  5. 程序员的长安十二时辰:Java实现从Google oauth2.0认证调用谷歌内部api

    最近公司在做一个app购买的功能,主要思路就是客户在app上购买套餐以后,Google自动推送消息到Java后端,然后Java后端通过订单的token获取订单信息,保存到数据库. Java后端要获取订 ...

  6. 【转】Eclipse中查看jar包中的源码

    (简单的方式:通过jd-gui来进行反编译,最简单!,参考我的另一篇博文, 地址:http://www.cnblogs.com/gmq-sh/p/4277991.html) Java Decompil ...

  7. JDK中的Atomic包中的类及使用

    引言 Java从JDK1.5开始提供了java.util.concurrent.atomic包,方便程序员在多线程环境下,无锁的进行原子操作.原子变量的底层使用了处理器提供的原子指令,但是不同的CPU ...

  8. Package.json中dependencies依赖包中^符号和~符号前缀的区别

    刚git了webpack的包发现package.json里面dependencies依赖包的版本号前面的符号有两种,一种是~,一种是^,如下图标记: 然后搜了下在stackoverflow上找到一个比 ...

  9. Java8系列 (六) 新的日期和时间API

    概述 在Java8之前, 我们一般都是使用 SimpleDateFormat 来解析和格式化日期时间, 但它是线程不安全的. @Test public void test() { SimpleDate ...

  10. Java8 新的日期和时间API(笔记)

    LocalDate LocalTime Instant duration以及Period 使用LocalDate和LocalTime //2017-03-20 LocalDate date = Loc ...

随机推荐

  1. 代码随想录Day1

    704.二分查找 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1. 示例 1: ...

  2. 代码随想录Day2

    209.长度最小的子数组 给定一个含有 n 个正整数的数组和一个正整数 target . 找出该数组中满足其总和大于等于 target 的长度最小的 子数组 $ [nums_l, nums_{l+1} ...

  3. nvidia官方AI框架软件的命令行操作接口 —— NVIDIA GPU Cloud (NGC) CLI

    NVIDIA GPU Cloud (NGC) CLI 安装介绍地址: https://org.ngc.nvidia.com/setup/installers/cli 安装好后需要输入自己的NVIDIA ...

  4. python编程中的circular import问题

    循环引入,circular import是编程语言中常见的问题,在C语言中我们可以使用宏定义来处理,在c++语言中我们可以使用宏定义和类的预定义等方式来解决,那么在python编程中呢? 其实在pyt ...

  5. 再探 游戏 《 2048 》 —— AI方法—— 缘起、缘灭(8) —— 2021年9月SOTA的TDL算法——《Optimistic Temporal Difference Learning for 2048》——完结篇

    <2048>游戏在线试玩地址: https://play2048.co/ 如何解决<2048>游戏源于外网的一个讨论帖子,而这个帖子则是讨论如何解决该游戏的最早开始,可谓是&q ...

  6. Apache DolphinScheduler数仓任务管理规范

    前言: 大数据领域对多种任务都有调度需求,以离线数仓的任务应用最多,许多团队在调研开源产品后,选择Apache DolphinScheduler(以下简称DS)作为调度场景的技术选型.得益于DS优秀的 ...

  7. 在 React 项目中 Editable Table 的实现

    我们是袋鼠云数栈 UED 团队,致力于打造优秀的一站式数据中台产品.我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值. 本文作者:佳岚 可编辑表格在数栈产品中是一种比较常见的表单数据交互方 ...

  8. Java基础之时间类

  9. 工作常用SQL

    工作常用SQL Excel生成SQL 这个好用 ="insert into t_gk_mapping(id,gk_project_name,gk_project_code,main_proj ...

  10. [VS Code扩展]写一个代码片段管理插件(二):功能实现

    @ 目录 创建和插入代码片段 代码片段列表 代码片段预览 代码片段编辑 自定义映射 默认映射 自动完成 项目地址 创建和插入代码片段 VS Code扩展提供了数据存储,其中globalState是使用 ...