Date、LocalDateTime、时间戳、日期字符串互转

2024-05-24 09:52

本文主要是介绍Date、LocalDateTime、时间戳、日期字符串互转,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

由于历史原因,项目上使用Date、LocalDateTime、时间戳甚至日期字符串的情况五花八门,在每次参数传递的时候,遇到类型不一致的时候就会很痛苦,接下来就总结下这些类之间到底怎样互转。

1 From Date

Date作为老牌的日期处理类,用到它的地方一定很多,首先针对Date做下总结:

1.1 dateToString

// 经典的SimpleDateFormat,注意SimpleDateFormat是非线程安全的,所以每次使用都要new一个对象
public static String dateToString(Date date) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");return sdf.format(date);
}

1.2 dateToTimestamp

// Date转毫秒时间戳
public static long dateToMilliSeconds(Date date) {return date.getTime();
}// Date转秒时间戳
public static long dateToSeconds(Date date) {return date.getTime() / 1000;
}// Date转纳秒时间戳, 由于Date只精确到毫秒级,所以直接乘以6个0即可
public static long dateToNanos(Date date) {return date.getTime() * 1000 * 1000;
}

1.3 dateToLocalDateTime

public static LocalDateTime dateToLocalDateTime(Date date) {long milliSeconds = date.getTime();Instant instant = Instant.ofEpochMilli(milliSeconds);return LocalDateTime.ofInstant(instant);
}

2 From LocalDateTime

2.1 localDateTimeToString

public static DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");public static String localDateTimeToString(LocalDateTime localDateTime) {return dateTimeFormatter.format(localDateTime);
}

2.2 localDateTimeToTimestamp

public static ZoneId zoneId = ZoneId.systemDefault();// 转毫秒时间戳
public static long localDateTimeToMilliSeconds(LocalDateTime localDateTime) {return localDateTime.atZone(zoneId).toInstant().toEpochMilli();
}// 转秒时间戳
public static long localDateTimeToSeconds(LocalDateTime localDateTime) {return localDateTime.atZone(zoneId).toEpochSecond();
}// 转"秒.纳秒"时间戳
public static String localDateTimeToNanos(LocalDateTime localDateTime) {ZonedDateTime zonedDateTime = localDateTime.atZone(zoneId);return String.format("%d.%d", zonedDateTime.toEpochSecond(), zonedDateTime.getNano()));

2.3 LocalDateTimeToDate

public static LocalDateTime localDateTimeToDate(LocalDateTime localDateTime) {ZoneId zoneId = ZoneId.systemDefault();ZonedDateTime zonedDateTime = localDateTime.atZone(zoneId);Instant instant = zonedDateTime.toInstant();long milliSeconds = instant.toEpochMilli();return new Date(milliSeconds);
}

这篇关于Date、LocalDateTime、时间戳、日期字符串互转的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/998077

相关文章

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

MySQL按时间维度对亿级数据表进行平滑分表

《MySQL按时间维度对亿级数据表进行平滑分表》本文将以一个真实的4亿数据表分表案例为基础,详细介绍如何在不影响线上业务的情况下,完成按时间维度分表的完整过程,感兴趣的小伙伴可以了解一下... 目录引言一、为什么我们需要分表1.1 单表数据量过大的问题1.2 分表方案选型二、分表前的准备工作2.1 数据评估

Python 字符串裁切与提取全面且实用的解决方案

《Python字符串裁切与提取全面且实用的解决方案》本文梳理了Python字符串处理方法,涵盖基础切片、split/partition分割、正则匹配及结构化数据解析(如BeautifulSoup、j... 目录python 字符串裁切与提取的完整指南 基础切片方法1. 使用切片操作符[start:end]2

MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)

《MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)》本文给大家介绍MyBatis的xml中字符串类型判空与非字符串类型判空处理方式,本文给大家介绍的非常详细,对大家的学习或... 目录完整 Hutool 写法版本对比优化为什么status变成Long?为什么 price 没事?怎

MySQL中DATE_FORMAT时间函数的使用小结

《MySQL中DATE_FORMAT时间函数的使用小结》本文主要介绍了MySQL中DATE_FORMAT时间函数的使用小结,用于格式化日期/时间字段,可提取年月、统计月份数据、精确到天,对大家的学习或... 目录前言DATE_FORMAT时间函数总结前言mysql可以使用DATE_FORMAT获取日期字段

Python标准库datetime模块日期和时间数据类型解读

《Python标准库datetime模块日期和时间数据类型解读》文章介绍Python中datetime模块的date、time、datetime类,用于处理日期、时间及日期时间结合体,通过属性获取时间... 目录Datetime常用类日期date类型使用时间 time 类型使用日期和时间的结合体–日期时间(

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1