将日期和时间字符串连接到DateTime

时间:2013-05-31 19:31:13

标签: c# datetime

给出两个具有以下值的字符串:

31/05/2013 0:00:00
21:22

将这些数据类型加入DateTime数据类型的最有效方法是:

31/05/2013 21:22

忽略第一个字符串“0:00:00”的时间部分,支持使用第二个字符串中的“time”。

8 个答案:

答案 0 :(得分:8)

使用TimeSpan对象和DateTime.Add(yourTimeSpan);例如

DateTime dt = new DateTime(2013,05,31);
var dts = dt.Add(new TimeSpan(0, 21, 22, 0, 0));

稍微扩展答案,您可以先解析日期和时间,例如

DateTime dt = DateTime.Parse("05/31/2013 0:00:00");
TimeSpan ts = TimeSpan.Parse("21:22");
var dts = dt.Add(ts);

...请记住,我没有检查错误的日期/时间值。如果您不确定值是否为实际日期/时间,请使用DateTime.TryParse并正确处理。

答案 1 :(得分:1)

正如@George所说,将第一个值解析为DateTime,然后将另一个值解析为TimeSpan,然后将TimeSpan添加到第一个解析值。

另一种选择是获取前10个第一个值的字符串的子字符串,并用第二个值的空格连接它,并将其解析为DateTime。

答案 2 :(得分:0)

假设第一个字符串名为one,第二个字符串名为two,请执行以下操作:

DateTime result = DateTime.Parse(one).Date + DateTime.Parse(two).TimeOfDay;

答案 3 :(得分:0)

string strDate = "31/05/2013 0:00";
string strTime = "21:22";
strDate = strDate.Replace("0:00", strTime);
DateTime date = Convert.ToDateTime(strDate);

答案 4 :(得分:0)

如果你刚刚开始使用字符串,你可以这样做:

var dateString = "31/05/2013 00:00";
var timeString = "21:22";
var dateTimeString = dateString.Substring(0, 11) + timeString;
var output = DateTime.ParseExact(dateTimeString, "dd/MM/yyyy HH:mm", null);

假设你确定这种格式不会改变(这是一个危险的假设,确定),这将有效。否则,您必须分别解析日期和时间字符串,并使用其他人建议的传统日期操作。例如:

var ci = System.Globalization.CultureInfo.CreateSpecificCulture("en-GB");
var dateString = "31/05/2013 00:00";
var timeString = "21:22";
var output = DateTime.Parse(dateString, ci) + TimeSpan.Parse(timeString, ci);

答案 5 :(得分:0)

  DateTime date = DateTime.ParseExact("31/05/2013 0:00:00", "dd/MM/yyyy h:mm:ss", CultureInfo.InvariantCulture);
  TimeSpan span = TimeSpan.ParseExact("21:22", "t", CultureInfo.InvariantCulture);
  DateTime result = date + span;

答案 6 :(得分:0)

如果你真的只处理字符串,那么:

string strDate = "31/05/2013 0:00:00";
string strTime = "21:22";
string strDateTime = strDate.Split(' ')[0] + " " + strTime;

答案 7 :(得分:0)

如果您可以安全地假设您的月份和日期为2位数,则为4位数年份,日期后为空格:

var date = "31/05/2013 0:00:00";
var time = "21:22";
var dateTime = DateTime.Parse(date.Substring(0,11) + time);

如果关于输入格式的假设不稳定,您可以使用正则表达式来提取日期而不是Substring