格式化长日期时间字符串以删除T字符

Mas*_*oda 5 c# regex xml

我有许多XML节点,它们将datetime对象输出为字符串。

问题在于,当同时输出时间戳和日期时,它们会与T字符绑定在一起。

这是一个例子

2016-01-13T23:59:59

当然,XML中的所有节点都是不同的类型,因此按名称或类型进行分组是不可能的。我认为我唯一的选择是用正则表达式匹配模式并以这种方式解决问题。

下面是XML的工作方式示例,您可以看到每个元素的名称都不同,但是它们都遵循类似的模式,其中必须删除日期和时间之间的T,并替换一个空格。

<dates>
    <1stDate> 2016-01-13T23:59:59 </1stdate>
    <2ndDate> 2017-01-13T23:55:57 </2ndDate>
    <3rdDate> 2018-01-13T23:22:19 </3rdDate>
</dates>
Run Code Online (Sandbox Code Playgroud)

像这样输出的理想解决方案

2016-01-13 23:59:59 
2017-01-13 23:55:57 
2018-01-13 23:22:19
Run Code Online (Sandbox Code Playgroud)

我以前不必使用Regex,但我知道它是什么。我一直在尝试解释该备忘单的含义,即http://regexlib.com/CheatSheet.aspx?AspxAutoDetectCookieSupport=1,但无济于事。

更新

//How each node is output
foreach (XText node in nodes)
{
    node.Value = node.Value.Replace("T"," "); // Where a date occurs, replace T with space. 
}
Run Code Online (Sandbox Code Playgroud)

<date>示例中提供的元素可能在我的XML中包含日期,但可能不包含单词date作为名称。

例如

<Start>  2017-01-13T23:55:57  </start>
<End>    2018-01-13T23:22:19  </End>
<FirstDate> 2018-01-13T23:22:19 </FirstDate>
Run Code Online (Sandbox Code Playgroud)

我本来希望使用正则表达式解决方案的主要原因是因为我需要将日期字符串与可以确定其日期与否的模式进行匹配,然后才能应用格式设置。

Oct*_*oid 5

为什么不将那个(完全有效的ISO-8601)日期时间解析为DateTime,然后使用内置的字符串格式生成可显示的人类可读日期时间?

if (!string.IsNullOrWhiteSpace(node.Value))
{
    DateTime date;
    if (DateTime.TryParseExact(node.Value.Trim(),
        @"yyyy-MM-dd\THH:mm:ss", 
        CultureInfo.InvariantCulture, 
        DateTimeStyles.AssumeUniversal, 
        out date)
    {
        node.Value = date.ToString("yyyy-MM-dd HH:mm:ss");
    }
}
Run Code Online (Sandbox Code Playgroud)