C#下 OADate(double类型)日期转换成常规时间DateTime

出现场景:在进行一些文档导入,数据库文件读取时候存在时间属性的字段为duoble类型的数字,在程序中转换成DateTime类型出现问题

 解决方式

1、DateTime时间转OAdate时间

//当前时间转OADate
DateTime dt = DateTime.Now;//2023-06-30 12:00:00
var OADate = dt.ToOADate();//45107.5

2、OAdate时间转DateTime时间

//把45107.5转换成2023-06-30 12:00:00
var OADate = Math.Round(Convert.ToDouble(45107.5) * 24 * 60 * 60 * 1000);//先转成Timestamp
var stampTime = DateTime.Parse("1899-12-30").ToTimestampLong() + OADate;
var dt = new DateTime(1970, 1, 1, 0, 0, 0, 0);//初始时间
var Time = dt.Ticks + stampTime * 10000;
var DateTime = new DateTime(Convert.ToInt64(Time)).AddHours(8);//存在8小时时区差,需要添加
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值