Easy-DotNET Easy-DotNET
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
npm
  • 简介
  • ORM

    • EFCore
    • Dapper
    • FreeSql
    • SqlSugar
  • 任务调度

    • Hangfire
    • Quartz
    • FluentScheduler
    • Coravel
    • Quartzmin
  • 日志

    • Serilog
    • NLog
    • Log4Net
    • Stackdriver
    • ExceptionLess
  • 身份认证与授权

    • IdentityServer4
    • Identity
    • JWTBearer
    • Auth0
    • OpenIddict
  • Swagger文档

    • Swagger
    • Swashbuckle
    • NSwag
    • ReDoc
  • 对象映射

    • AutoMapper
    • EmitMapper
    • AgileMapper
    • Mapster
  • 消息传递

    • MediatR
    • MassTransit
    • Rebus
    • NServiceBus
  • 熔断重试限流

    • Polly
    • Resilience4j
    • AkkaNET
  • 缓存

    • CsRedis
    • FreeRedis
    • EasyCaching
    • StackExchangeRedis
    • CacheCow
    • NCache
    • Memory
  • 注册发现

    • Consul
    • Nacos
    • Apollo
  • 网关

    • Ocelot
    • Kong
    • Traefik
    • Zuul
  • GraphQL

    • GraphQLPlatform
    • GraphQLdotnet
  • 更多

    • NodaTime
      • 安装
      • 基本概念
        • Instant
        • Duration
        • LocalDate 和 LocalDateTime
        • ZonedDateTime
        • Period
        • CalendarSystem
        • DateTimeZone
      • 使用示例
        • 创建 Instant
        • 创建 Duration
        • 创建 LocalDate 和 LocalDateTime
        • 创建 ZonedDateTime
        • 创建 Period
        • 创建 CalendarSystem
        • 创建 DateTimeZone
        • 转换时间
        • 格式化输出
        • 处理时区
        • 支持多种日历系统
        • 支持多种语言
      • 总结
    • FluentAssertions
    • Humanizer
    • 爬虫-AngleSharp
    • 邮件-MailKit
  • NET微服务
  • 更多
一个大西瓜
2023-04-25
目录

NodaTime

开源地址

Github:https://github.com/nodatime/nodatime (opens new window)

NodaTime 是一个专门为 .NET 设计的日期和时间库。它旨在提供一种更好的方式来处理日期和时间,以解决在 .NET 中使用日期和时间时经常遇到的一些问题。NodaTime 提供了一种强类型和不可变的方式来表示日期和时间,并且支持多种不同的日历系统和时区。在本文中,我们将介绍 NodaTime 的基本概念和使用方法。

# 安装

要开始使用 NodaTime,首先需要将其安装到你的 .NET 项目中。可以使用 NuGet 包管理器来安装 NodaTime。在 Visual Studio 中,打开“包管理器控制台”,然后运行以下命令:


Install-Package NodaTime

这将安装 NodaTime 的最新版本。

# 基本概念

在开始使用 NodaTime 之前,有几个基本概念需要了解。

# Instant

NodaTime 中的 Instant 表示一个精确的时间点。它类似于 .NET 中的 DateTime,但是更加精确,并且可以表示更远的时间范围。

# Duration

Duration 表示一个时间段。它类似于 .NET 中的 TimeSpan,但是更加精确,并且支持更多的单位。

# LocalDate 和 LocalDateTime

LocalDate 和 LocalDateTime 分别表示一个本地日期和时间。它们类似于 .NET 中的 DateTime,但是更加精确,并且可以表示不同的日历系统。

# ZonedDateTime

ZonedDateTime 表示一个带时区的日期和时间。它包含一个 LocalDateTime 和一个对应的时区信息。

# Period

Period 表示两个 LocalDate 之间的时间段。它可以表示以年、月、日、时、分、秒、毫秒或微秒为单位的时间段。

# CalendarSystem

CalendarSystem 表示一个日历系统。NodaTime 支持多种不同的日历系统,包括 ISO、儒略历、波斯历、希伯来历等等。

# DateTimeZone

DateTimeZone 表示一个时区。它包含一组规则,可以用来将 UTC 时间转换为本地时间。

# 使用示例

# 创建 Instant

要创建一个 Instant,可以使用静态方法 FromUtcTicks:


var instant = Instant.FromUtc(2023, 4, 25, 10, 0, 0);

这将创建一个代表 2023 年 4 月 25 日上午 10 点的 Instant。

# 创建 Duration

要创建一个 Duration,可以使用静态方法 FromXxx:


var duration = Duration.FromHours(1.5);

这将创建一个代表一个半小时的 Duration。

# 创建 LocalDate 和 LocalDateTime

要创建一个 LocalDate,可以使用静态方法 FromXxx:


var localDate = LocalDate.FromDateTime(DateTime.Now);

这将创建一个代表当前本地日期的 LocalDate。

要创建一个 LocalDateTime,可以使用静态方法


var localDateTime = LocalDateTime.FromDateTime(DateTime.Now);

这将创建一个代表当前本地日期和时间的 LocalDateTime。

# 创建 ZonedDateTime

要创建一个 ZonedDateTime,需要先创建一个 LocalDateTime,然后将其与一个时区相关联:


var localDateTime = LocalDateTime.FromDateTime(DateTime.Now);
var timeZone = DateTimeZoneProviders.Tzdb["Asia/Shanghai"];
var zonedDateTime = localDateTime.InZoneStrictly(timeZone);

这将创建一个代表当前上海时间的 ZonedDateTime。

# 创建 Period

要创建一个 Period,可以使用静态方法 Between:


var start = new LocalDate(2023, 4, 25);
var end = new LocalDate(2023, 5, 1);
var period = Period.Between(start, end, PeriodUnits.Days);

这将创建一个代表从 2023 年 4 月 25 日到 2023 年 5 月 1 日的时间段。

# 创建 CalendarSystem

要创建一个 CalendarSystem,可以使用静态方法 ForId:


var calendar = CalendarSystem.ForId("ISO");

这将创建一个代表 ISO 日历系统的 CalendarSystem。

# 创建 DateTimeZone

要创建一个 DateTimeZone,可以使用 DateTimeZoneProviders 类:


var timeZone = DateTimeZoneProviders.Tzdb["America/New_York"];

这将创建一个代表纽约时区的 DateTimeZone。

# 转换时间

要将一个时间从一种表示方式转换为另一种表示方式,可以使用 NodaTime 提供的转换方法。

例如,要将一个 LocalDate 转换为一个 DateTime,可以使用 ToDateTimeUnspecified 方法:


var localDate = new LocalDate(2023, 4, 25);
var dateTime = localDate.ToDateTimeUnspecified();

这将创建一个代表 2023 年 4 月 25 日午夜的 DateTime。

要将一个 DateTime 转换为一个 Instant,可以使用静态方法 FromDateTimeUtc:


var dateTime = DateTime.UtcNow;
var instant = Instant.FromDateTimeUtc(dateTime);

这将创建一个代表当前 UTC 时间的 Instant。

# 格式化输出

要将一个时间格式化为一个字符串,可以使用 NodaTime 提供的格式化方法。

例如,要将一个 LocalDate 格式化为一个字符串,可以使用 ToString 方法:


var localDate = new LocalDate(2023, 4, 25);
var formattedString = localDate.ToString("yyyy-MM-dd");

这将创建一个代表 2023 年 4 月 25 日的字符串。

# 处理时区

NodaTime 提供了丰富的支持来处理时区。

例如,要将一个本地时间转换为一个带时区的时间,可以使用 InZone 方法:


var localDateTime = new LocalDateTime(2023, 4, 25, 10, 0, 0);
var timeZone = DateTimeZoneProviders.Tzdb["America/New_York"];
var zonedDateTime = localDateTime.InZoneStrictly(timeZone);

这将创建一个代表纽约时间的 ZonedDateTime。

要将一个带时区的时间转换为 UTC 时间,可以使用 ToInstant 方法:


var zonedDateTime = new ZonedDateTime(
    new LocalDateTime(2023, 4,25, 10, 0, 0),DateTimeZoneProviders.Tzdb["America/New_York"]
);
var instant = zonedDateTime.ToInstant();

这将创建一个代表纽约时间的 Instant,并将其转换为 UTC 时间。

# 支持多种日历系统

NodaTime 支持多种不同的日历系统。要使用一个特定的日历系统,可以创建一个对应的 CalendarSystem 实例,然后使用它来创建 LocalDate 或 LocalDateTime。

例如,要使用波斯历创建一个 LocalDate,可以使用如下代码:

var calendar = CalendarSystem.GetPersianCalendar();
var localDate = new LocalDate(1402, 2, 5, calendar);

这将创建一个代表波斯历的 LocalDate。

# 支持多种语言

NodaTime 支持多种不同的语言和文化。要使用一个特定的语言和文化,可以创建一个对应的 CultureInfo 实例,并将其传递给 ToString 方法。

例如,要将一个 LocalDate 格式化为中文,可以使用如下代码:


var localDate = new LocalDate(2023, 4, 25);
var formattedString = localDate.ToString("D", CultureInfo.GetCultureInfo("zh-CN"));

这将创建一个代表 2023 年 4 月 25 日的中文字符串。

# 总结

NodaTime 提供了一种更好的方式来处理日期和时间,以解决在 .NET 中使用日期和时间时经常遇到的一些问题。它提供了一种强类型和不可变的方式来表示日期和时间,并且支持多种不同的日历系统和时区。在使用 NodaTime 时,我们需要了解其基本概念,并使用提供的 API 来进行时间的创建、转换和格式化。

上次更新: 2023/04/26, 22:10:06
GraphQLdotnet
FluentAssertions

← GraphQLdotnet FluentAssertions→

Theme by Vdoing | Copyright © 2019-2024 一个大西瓜 | MIT License | 苏ICP备2023013501号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式