- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在尝试从字符串中检索时间跨度,但 TryParseExact 返回 false(失败)。
我看不出我做错了什么,你能帮忙吗?我在代码中尝试了我的行的 2 个版本,都不起作用。
TimeSpan.TryParseExact("04:00:01","HH:mm:ss",CultureInfo.CurrentCulture, out aTime)
和
TimeSpan.TryParseExact("04:00:01","HH:mm:ss", null, out aTime)
编辑:这里的两个响应都是正确的,我的自定义时间跨度格式有误 - 我犯的错误是假设 DateTime 的自定义格式适用于 TimeSpans,但事实并非如此。
最佳答案
问题仅出在 TimeSpan 的格式字符串中,您指定了 "HH:mm:ss"
。说明符 HH
(大写)对于时间跨度无效。你应该使用 hh
。格式字符串确实区分大小写。
冒号字符(:
)也需要转义,所以使用"hh\\:mm\\:ss"
,@"hh\:mm\:ss"
或 "hh':'mm':'ss"
。所有三种形式都具有相同的效果。
您可以查看 TimeSpan here 的有效自定义格式字符串列表. TimeSpan 的标准格式字符串是 here .
虽然 HH
对 DateTime 和 DateTimeOffset 有效,其中它代表 24 小时制,小写 hh 代表 12 小时制,但对于 TimeSpan - 小时部分始终基于 24 小时制。您可能会认为选择 HH
格式是为了统一,但不是的 - 它是 hh
。
关于c# - TimeSpan.TryParseExact 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13042675/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Parse DateTime with timezone of form PST/CEST/UTC/etc
我在 linqpad 中使用以下代码(删除 native C# 的 .Dump()): string dateTime = "3/20/2015 1:45:00 PM"; string dateF
我对 tryparseexact 方法的工作原理有疑问。 因为我需要将 excel 数据上传到 sql server 的任务。我需要从 excel 转换 sql 中的日期时间列。但我在 EXCEL 中
这个问题在这里已经有了答案: DateTime conversion from string C# (3 个答案) 关闭 5 年前。 我有一个没有字段分隔符的时间和日期值,我试图使用 TryPars
是否可以指示 DateTime.TryParseExact 接受多个( 任何 )分隔符( 指定分隔符占位符而不是特定分隔符 )?例如: DateTime.TryParseExact(performan
如何使用 DateTime.TryParseExact 进行防护(并尽可能获取解析值)?以下代码不起作用。 [] let main args = let argList = args |> L
使用下面的 DateTime.TryPaseExact 方法会在预期的时候给出不同的输出。 我从下面的代码中返回了以下格式: 2014-02-10 18:32:37 1402-10-18 17:23:
知道为什么当我的字符串中有时间 "00:00:00" 时这不起作用吗? DateTime.TryParseExact("01/06/2015 00:00:00", "dd/MM/yyyy", Cult
下面的代码工作正常,只是想知道是否有更优雅的方式来实现同样的事情?下面的日期应该是有效的,除此之外的任何其他日期都不应该: 1/12/2017 1/12/2017 11:10 1/12/2017 11
为什么这不起作用? DateTime.TryParseExact(text, "H", CultureInfo.InvariantCulture, DateTimeStyles.AllowWhiteS
我讨厌问愚蠢的问题,但我已经浏览了 MSDN 文章几次并尝试了一个小时,但无论我尝试什么,我都无法让这种格式工作。这是我要解析的内容: Thu, Jun 22 与 bool parsed = Date
我正在尝试解析一个巨大的文件,其中包含一些 DateTime 行。出于某种原因,DateTime.TryParseExact 仅在某些行而不是其他行上返回 true。 我的 DateParse.txt
为什么会 DateTime.TryParseExact("08/10/2013", "dd/MM/yyyy", null, DateTimeStyles.None, out dateValue)
下面的代码片段显示“07/01/2011”而不是“07/09/2011”。这段代码有什么问题吗? 代码片段: DateTime result; DateTime.TryParseExact( "
我正在对要解析为 DateTime 的字符串调用 TryParse。简单的东西。当格式符合我的预期时,这一切都有效。但是当日期的每个组成部分/部分组成部分是单个数字时,解析失败。 例子: var da
我无法完成这项工作 - 它总是返回 False。 我在这里错过了什么? DateTimeOffset parsedDate; if ( DateTimeOffset.TryParseExact("20
我在使用 DateTime.ParseExact(..) 将 DateTime 值的字符串表示形式解析回 DateTime 实例时遇到问题方法。 出于某种原因,使用具有不同值的类似格式化字符串(或者我
我有一个包含日期时间值的 json 字符串和如下所示的解析机制: if (DateTime.TryParseExact(TheUserTimeString, "M.d.yyyy.HH.mm", Cul
您好,我有以下方法,我将值“2014 年 1 月 7 日 13:48:46”传递给它,据我所知,TryParseExact 应该匹配格式“dd MMM yyyy hh:mm:ss”和返回 true,但
谁能解释为什么下面的代码片段返回 true? 根据 The "d" custom format specifier 的文档, "个位数的日期格式不带前导零。"那么,当我给它一个带前导零的个位数日时,为
我是一名优秀的程序员,十分优秀!