使用System.Globalization.CultureInfo.InvariantCulture进行字符串到日期时间的转换

Sil*_*ver 5 c# mysql datetime

我有以下代码将字符串转换为datetime ..

string updateDateTime = "1398398552695";

double temp = Double.Parse(updateDateTime);
TimeSpan sp = TimeSpan.FromMilliseconds(temp);
DateTime dt = new DateTime(1970, 1, 1).Add(sp);
updateDateTime = dt.ToString("yyyy-MM-dd HH':'mm':'ss");//final date time

string tt = dt.ToString("yyyy-MM-dd HH':'mm':'ss");
DateTime output1;
DateTime.TryParseExact(tt, "yyyy-MM-dd HH':'mm':'ss", System.Globalization.CultureInfo.InvariantCulture,System.Globalization.DateTimeStyles.None,out output1);

DateTime output2 = DateTime.ParseExact(tt, "yyyy-MM-dd HH':'mm':'ss", System.Globalization.CultureInfo.InvariantCulture);

Console.WriteLine(dt);
Console.WriteLine(tt);
Console.WriteLine(output1);
Console.WriteLine(output2);
Run Code Online (Sandbox Code Playgroud)

如果我们看到输出它将是这样的..

25/04/2014 04:02:32//dt
2014-04-25 04:02:32//tt
25/04/2014 04:02:32//output1
25/04/2014 04:02:32//output2
Run Code Online (Sandbox Code Playgroud)

问题是,如果我们看到output1和output2它实际上没有给出yyyy-MM-dd格式的结果,并且我需要这种格式的值,并且在datetime类型中只有coz in数据库(MySQL),该字段是DateTime格式.所以,我希望输出在2014-04-25 04:02:32格式,但它是字符串,我需要将其转换为日期时间.

注意:stackoverflow中存在许多与此问题相关的问题,但我的声誉不足以对它们进行评论,因此我不得不创建这个新问题.

sir*_*ju1 2

您的日期时间以这种方式显示,因为您的Region Settings日期Control Panel和时间格式是这样设置的。

请转到控制面板并选择区域,然后在“格式”选项卡中选择正确的值,或者转到“其他设置”以自定义日期和时间格式。