C#日期和时间:DateTime转字符串全面指南

C#日期和时间:DateTime转字符串全面指南

在 C# 开发中,DateTime类型的时间格式化是高频操作场景。无论是日志记录、数据持久化,还是接口数据交互,合理的时间字符串格式都能显著提升系统的可读性和兼容性。本文将通过 20 + 实战示例,全面解析DateTime转换为字符串的核心方法与最佳实践。

一、基础转换方法:快速获取常用格式

1. 无参 ToString ():本地化默认格式

DateTime.Now.ToString(); // 2023-10-25 14:30:45(依赖系统区域设置)

该方法返回基于当前系统文化设置的默认格式,适用于快速调试,但不建议用于跨环境交互。

2. 系统时间相关方法

方法 示例输出 用途说明
ToFileTime()133756416859912816 获取 Windows 文件时间(长整型)
ToFileTimeUtc()133756704859912816 UTC 格式的文件时间
ToLocalTime()2023-10-25 22:30:45 转换为本地时区时间
ToUniversalTime()2023-10-25 06:30:45 转换为 UTC 时间

3. 预定义格式方法

DateTime.Now.ToLongDateString(); // "2023年10月25日"(中文环境)
DateTime.Now.ToShortDateString(); // "2023-10-25"
DateTime.Now.ToLongTimeString(); // "14:30:45"
DateTime.Now.ToShortTimeString(); // "14:30"

这些方法提供了日期和时间的粗细粒度划分,适用于需要快速生成特定格式的场景。

二、自定义格式字符串:精准控制输出

1. 标准格式说明符(单个字符)

通过ToString(string format)string.Format使用格式字符:

格式符 示例(2023-10-25 14:30:45) 说明
d2023-10-25 短日期格式
D2023 年 10 月 25 日 长日期格式
t14:30 短时间格式
T14:30:45 长时间格式
f2023 年 10 月 25 日 14:30 完整日期 + 短时间
F2023 年 10 月 25 日 14:30:45 完整日期 + 长时间
s2023-10-25T14:30:45 ISO 8601 排序日期格式
u2023-10-25 14:30:45Z UTC 通用排序格式
rWed, 25 Oct 2023 14:30:45 GMT RFC 1123 标准格式

示例代码:

DateTime.Now.ToString("s"); // "2023-10-25T14:30:45"(适合API返回)
string.Format("{0:u}", DateTime.Now); // "2023-10-25 14:30:45Z"(UTC标准化)

2. 自定义格式符(组合字符)

通过组合yyyy/MM/dd HH:mm:ss等字符实现任意格式:

字符 说明 示例(2023-10-25 14:30:45)
yyyy四位数年份 2023
MM两位数月份(01-12) 10
dd两位数日期 25
HH24 小时制小时(00-23) 14
mm分钟(00-59) 30
ss秒(00-59) 45
fff毫秒(000-999) 450

复杂示例:

// 生成带毫秒的日志时间戳
DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff"); // "2023-10-25 14:30:45.450"// 生成Excel兼容的日期时间
DateTime.Now.ToString("yyyy/mm/dd hh:mm:ss tt"); // "2023/10/25 02:30:45 下午"(带AM/PM标识)

三、高级时间操作与格式处理

1. 时间偏移与计算

通过Add系列方法实现时间加减后格式化:

// 增加1.5天(36小时)
DateTime.Now.AddDays(1.5).ToString("yyyy-MM-dd HH:mm"); // "2023-10-27 02:30"// 增加10000 ticks(1毫秒=10000 ticks)
DateTime.Now.AddTicks(10000).ToString("yyyy-MM-dd HH:mm:ss.fff"); // 精确到毫秒级增量

2. 多文化格式支持

通过CultureInfo指定非默认文化格式:

using System.Globalization;// 生成法语格式日期
DateTime.Now.ToString("D", CultureInfo.CreateSpecificCulture("fr-FR")); // "25 octobre 2023"// 生成日本格式时间
DateTime.Now.ToString("t", CultureInfo.GetCultureInfo("ja-JP")); // "14:30"

3. 特殊格式处理

需求场景 实现代码 输出示例
生成 ISO 8601 完整格式 DateTime.UtcNow.ToString("yyyy-MM-ddTHH:mm:ssZ")“2023-10-25T06:30:45+08:00”
去除时间部分 DateTime.Now.Date.ToString("yyyy-MM-dd")“2023-10-25”
生成时间戳(秒级) ((DateTimeOffset)DateTime.Now).ToUnixTimeSeconds().ToString()“1698220245”
生成时间戳(毫秒级) ((DateTimeOffset)DateTime.Now).ToUnixTimeMilliseconds().ToString()“1698220245450”

四、常见问题与最佳实践

1. 时区转换陷阱

  • UTC 与本地时间:始终明确时间的时区属性,避免混合使用ToLocalTime()ToUniversalTime()
  • 跨平台兼容性:优先使用ISO 8601格式(如s/u/r),避免依赖系统区域设置

2. 性能优化

  • 高频转换场景使用StringBuilder而非字符串拼接
  • 预定义格式字符串可缓存重用,避免重复解析

3. 空值处理

DateTime? nullableDate = null;
string result = nullableDate?.ToString("yyyy-MM-dd") ?? "未指定时间"; // 安全转换

4. 单元测试建议

对关键格式进行断言测试:

var date = new DateTime(2023, 10, 25, 14, 30, 45);
Assert.AreEqual("2023-10-25", date.ToString("d"));
Assert.AreEqual("25 octobre 2023", date.ToString("D", CultureInfo.French));

五、总结:选择合适的格式化方案

场景分类 推荐方法 示例代码 优势特点
快速调试 ToString()DateTime.Now.ToString()无需参数,快速查看
标准化输出 标准格式符(如 “s”/“u”) date.ToString("s")跨平台兼容
自定义格式 自定义格式字符串 date.ToString("yyyy/MM/dd HH:mm")灵活控制输出样式
跨文化支持 CultureInfo的 ToString date.ToString("D", fr-FR)多语言环境适配
时间戳生成 ToUnixTimeSeconds/ToFileTime((DateTimeOffset)date).ToUnixTimeSeconds()数值化时间表示

掌握DateTime的格式化技巧,能有效提升系统在数据交互、日志记录、报表生成等场景的健壮性。建议在实际开发中根据具体需求(如目标系统格式要求、性能敏感度、文化兼容性)选择最合适的转换方案,并通过单元测试确保格式的一致性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/diannao/84198.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Canvas设计图片编辑器全讲解(一)Canvas基础(万字图文讲解)

一、前序 近两年AI发展太过迅速,各类AI产品层出不穷,AI绘图/AI工作流/AI视频等平台的蓬勃发展,促使图片/视频等复杂内容的创作更加简单,让更多普通人有了图片和视频创作的机会。另一方面用户内容消费也逐渐向图片和视频倾斜。在“…

Javase易混点专项复习02_static关键字

1. static关键字1.1概述1.2修饰一个成员变量例:1.2.1静态属性与非静态属性示例及内存图对比 1.3修饰一个方法(静态方法)1.4.static修饰成员的访问特点总结1.5动态代码块和静态代码块1.5.1动态代码块1.5.2 静态代码块 1.6带有继承的对象创建过…

C++滑动门问题(附两种方法)

题目如下&#xff1a; 滑动窗口 - 题目 - Liusers OJ ——引用自OJ网站 方法如下&#xff1a; 1.常规思想 #include<bits/stdc.h> using namespace std; int main() {int n,k;int a[110];cin>>n>>k;for(int i0;i<n;i){cin>>a[i];}for(int i0;i…

mysql连接池druid监控配置

文章目录 前置依赖启用配置访问监控一些问题 前置 连接池有很多类型&#xff0c;比如 c3p0&#xff0c;比如 hikariCP&#xff0c;比如 druid。c3p0 一些历史项目可能用的比较多&#xff0c;hikariCP 需要高性能的项目比较多&#xff0c;druid 性能也很好&#xff0c;而且还提…

Jetson系统烧录与环境配置全流程详解(含驱动、GCC、.Net设置)

Jetson系统烧录与环境配置全流程详解&#xff08;含驱动、GCC、.Net设置&#xff09; 目录1. 准备工作与工具安装1.1 主机系统要求1.2 安装 SDK Manager 2. JetPack 系统烧录流程2.1 Jetson 进入恢复模式2.2 使用 SDK Manager 烧录 JetPack 3. Jetson 系统基础设置4. 配置 .Net…

分布式缓存:缓存的三种读写模式及分类

文章目录 缓存全景图Pre缓存读写模式概述1. Cache Aside&#xff08;旁路缓存&#xff09;工作流程优缺点 2. Read/Write Through&#xff08;读写穿透&#xff09;工作流程优缺点典型场景 3. Write Behind Caching&#xff08;异步写回&#xff09;工作流程优缺点典型场景 缓存…

Ntfs!FindFirstIndexEntry函数中ReadIndexBuffer函数的作用是新建一个Ntfs!_INDEX_LOOKUP_STACK结构

第一部分&#xff1a; 0: kd> kc # 00 Ntfs!FindFirstIndexEntry 01 Ntfs!NtfsRestartIndexEnumeration 02 Ntfs!NtfsQueryDirectory 03 Ntfs!NtfsCommonDirectoryControl 04 Ntfs!NtfsFsdDirectoryControl 05 nt!IofCallDriver 06 nt!IopSynchronousServiceTail 07 nt!Nt…

5.24 note

笛卡尔积(➕选择条件 select a.student_name as member_A, b.student_name as member_B, c.student_name as member_C from schoola as a join schoolb as b join schoolc as c where a.student_name ! b.student_name and a.student_name !…

为什么需要在循环里fetch?

假设有多个设备连接在后端,数量不定,需要按个读回状态,那么就要在循环里fetch了. 此函数非常好用,来自于国内一个作者,时间久了,忘记了来源,抱歉. export default async function fetchWithTimeout(resource, options {}) {const { timeout 1000 } options;const controll…

不同净化技术(静电 / UV / 湿式)的性能对比研究

在餐饮油烟和工业废气治理领域&#xff0c;油烟净化技术的选择至关重要。目前&#xff0c;静电、UV 光解、湿式洗涤是市场上应用较为广泛的三种净化技术。它们凭借不同的工作原理和技术特性&#xff0c;在净化效率、能耗、适用场景等方面展现出各自的优势与局限。本文将从多个维…

Ubuntu 22.04上升级npm版本

如果使用NVM安装Node.js npm会自动包含&#xff0c;但版本可能不是最新的。你可以选择升级&#xff1a; # 检查当前版本 npm --version# 升级到最新版本 npm install -g npmlatest# 或者升级到特定版本 npm install -g npm9.8.1如果使用其他方法安装Node.js 通常Node.js安装…

项目管理进阶:111页 详解华为业务变革框架及战略级项目管理【附全文阅读】

BTMS 是一套集成管理系统框架&#xff0c;涵盖变革规划、项目执行、实施及生命周期管理等多个关键环节。在规划阶段&#xff0c;通过全面收集需求、深入分析现状&#xff0c;制定出符合业务战略的年度规划&#xff0c;明确变革举措和项目清单。 解决方案开发的 PMOP 流程&#…

java基础知识回顾1(可用于Java基础速通)考前,面试前均可用!

目录 一、初识java 二、基础语法 1.字面量 2.变量 3.关键字 4.标识符 声明&#xff1a;本文章根据黑马程序员b站教学视频做的笔记&#xff0c;可对应课程听&#xff0c;课程链接如下: 02、Java入门&#xff1a;初识Java_哔哩哔哩_bilibili 一、初识java Java是美国 sun 公…

Linux下MySQL的安装与使用

1 安装前说明 1.1 Linux系统及工具的准备 安装并启动好两台虚拟机&#xff1a;CentOS 7 掌握克隆虚拟机的操作 mac地址主机名ip地址UUID 安装有 Xshell 和 Xftp 等访问 CentOS 系统的工具 CentOS6 和 CentOS7 在 MySQL 的使用中的区别 防火墙&#xff1a;6是iptables&am…

在react项目中使用andt日期组件,选择周和季度,直接获取所对应的日期区间

在react项目中使用andt日期组件&#xff0c;选择周和季度&#xff0c;直接获取所对应的日期区间 import { DatePicker, Space } from antd; import React from react; const onChange (date, dateString) > {console.log(date,dateString) }; const onChangeweek (date, …

数字信号处理大实验2 利用FFT估计信号的频率

目录 3.1 实验目的 3.2 实验内容与要求 3.3 实验原理 3.3.1 基于时域求导-频域乘法的n阶导数积分法 3.3.2 基于频域卷积的双/多谱线插值法 3.3.3 基于谱峰和滑动平均的多谱线综合插值方法 3.3.4 基于相邻显著谱线的滑动平均综合插值方法 3.3.5 基于&#xff08;2&#…

【Java】Java元注解

Target(ElementType.METHOD) Retention(value RetentionPolicy.RUNTIME) public interface OperatorLog {String source() default "WEB"; //日志操作来源 默认是web&#xff0c;还有socket的String model() default ""; //操作模块 }这个代码中的 Target…

阿里云百炼(1) : 阿里云百炼应用问答_回答图片问题_方案1_提问时上传图片文件

直接用于拍照答题不大理想, 可能适用其他用途, 更好的方案: 阿里云百炼(1) : 阿里云百炼应用问答_回答图片问题_方案2_提取题目再提问-CSDN博客 1.实现代码 package cn.nordrassil.ly.test.拍照答题;import com.alibaba.dashscope.app.Application; import com.alibaba.dashsc…

深入探索 CSS 中的伪类:从基础到实战​

在前端开发的世界里&#xff0c;CSS 作为网页样式的 “化妆师”&#xff0c;有着至关重要的作用。而 CSS 伪类则像是这位 “化妆师” 手中的神奇画笔&#xff0c;能够基于元素的状态或位置为其添加独特的样式&#xff0c;极大地丰富了网页的交互性和视觉效果。接下来&#xff0…

c++ constexpr关键字

constexpr字面意思为常量表格式&#xff0c; 用于指示编译器在编译时计算表达式的值。 1、作为常量表格式&#xff0c;必须在编译时就能确定其值。如&#xff1a;constexpr int size 9527; 2、可以修饰函数&#xff0c;要求能在编译时求值&#xff0c;所以传的参数也必须是编…