c# – 当天<= 12时的DateTime问题

c# – 当天<= 12时的DateTime问题,第1张

概述我已经环顾了很多,没有编写一大堆代码来 *** 作字符串,我想问一下是否有人知道一种很好的排序方式: 我在单元格中有一堆日期字符串,例如: 2011年3月5日 27/05/2011 31/05/2011 2011年3月5日 09/05/2011 31/05/2011 等等 当我正在阅读任何一天可以被解释为一个月的时候 – 即上面的条目1,4和5 – 它被作为DateTime与日期和月份交换. 例如,03/ 我已经环顾了很多,没有编写一大堆代码来 *** 作字符串,我想问一下是否有人知道一种很好的排序方式:

我在单元格中有一堆日期字符串,例如:

2011年3月5日
27/05/2011
31/05/2011
2011年3月5日
09/05/2011
31/05/2011
等等

当我正在阅读任何一天可以被解释为一个月的时候 – 即上面的条目1,4和5 – 它被作为DateTime与日期和月份交换.

例如,03/05/2011作为DateTime“05/03/2011 00:00:00”读入
其他人都读了,很好地为我提供了一个简单的“27/05/2011”字符串.

我从Excel中获取此信息,使用

((Excel.Range)worksheet.Cells[rowCount,3]).Value.ToString()

如果我像其他行一样尝试Value2,它会将这些奇怪的日期读作“40607”之类的内容,但同样会再次读取其他日期.

解决方法 如果使用 DateTime.ParseExact函数将字符串转换为DateTime对象,则可以指定日期使用的特定格式(看起来像“日/月/年”),而无需进行任何字符串 *** 作.

例:

var dateString = "03/05/2011";var format = "dd/MM/yyyy";var date = DateTime.ParseExact(dateString,format,CultureInfo.InvariantCulture);

有关自定义日期和时间格式字符串的更多信息,请参见here.

编辑:尝试使用DateTime.FromOADate方法将Range.Value2属性返回的值转换为DateTime对象,例如这样的事情:

var dateTime = DateTime.FromOADate(((Excel.Range)worksheet.Cells[rowCount,3]).Value2);
总结

以上是内存溢出为你收集整理的c# – 当天<= 12时的DateTime问题全部内容,希望文章能够帮你解决c# – 当天<= 12时的DateTime问题所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1261163.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-08
下一篇 2022-06-08

发表评论

登录后才能评论

评论列表(0条)

保存