繁体   English   中英

C#字符串迄今与CultureInfo

[英]C# String to date with CultureInfo

我有以下格式的日期。 始终采用这种格式。

yyyyMMdd  ->  20130912

我需要将其转换为日期。 但是我需要确保将日期转换为PC的正确日期格式。 Cultureinfo.InvariantCulture。 这是我的代码现在的样子。

DateTime parsedDateTime;
int year = Int32.Parse(rows[row][4].ToString().Substring(0, 4));
int month = Int32.Parse(rows[row][4].ToString().Substring(4, 2));
int day = Int32.Parse(rows[row][4].ToString().Substring(6, 2));
DateTime value = new System.DateTime(year, month, day);

bool DateTimeParseFail = DateTime.TryParse(value.ToString("yyyy-MM-dd"),   CultureInfo.InvariantCulture, DateTimeStyles.None, out parsedDateTime);

if (!DateTimeParseFail) {
   msg = "Data Feed Convert string to DateTime: Date " + rows[row][4].ToString() + " - " + value.ToString();
   ComponentMetaData.FireError(0, ComponentMetaData.Name, msg, string.Empty, 0, out pbCancel);
   throw new Exception(msg);
}  else {
   buffer[colIndex] = parsedDateTime;
}

对我来说,这似乎有点过分,我怀疑我对此考虑过度。 必须有一种更简单的方法来执行此操作。 但是我尝试过的所有方法都没有达到我的预期。

尝试这个:

string dateText = rows[row][4].ToString();
DateTime date = DateTime.ParseExact(dateText, "yyyyMMdd", CultureInfo.InvariantCulture);
string result = date.ToShortDateString(CultureInfo.InvariantCulture.DateTimeFormat.ShortDatePattern);

请注意,我假设您断言日期始终采用这种格式是正确的。 如果不是,您会发现代码抛出异常。

(您发布的代码表明您的断言不正确,因为那里有一个后备格式和一些失败处理方法。)

使用DateTime的TryParseExact。

var dateString = "20130912"; //rows[row][4].ToString()
DateTime parsedDateTime;
var DateTimeParseFail= DateTime.TryParseExact(dateString, "yyyyMMdd", CultureInfo.InvariantCulture, DateTimeStyles.None, out parsedDateTime);

if (!DateTimeParseFail) {
   msg = "Data Feed Convert string to DateTime: Date " + rows[row][4].ToString() + " - " + value.ToString();
   ComponentMetaData.FireError(0, ComponentMetaData.Name, msg, string.Empty, 0, out pbCancel);
   throw new Exception(msg);
}  else {
   buffer[colIndex] = parsedDateTime;
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM