Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

DateTime.ParseExact ignore first char C#

I get a string value from a device like "1140421164500". I have to convert it to DateTime type. I want to use DateTime.ParseExact function. I know that I can convert it by omitting the first char manually like the following:

DateTime.ParseExact("140421164500", "yyMMddHHmmss", CultureInfo.InvariantCulture);

But I want to avoid omitting the first char manually. I want to ignore it with a wildcard char in ParseExact function like:

DateTime.ParseExact("1140421164500", "*yyMMddHHmmss", CultureInfo.InvariantCulture);

Let me note that the first char can be 1 for daylight saving time is active, or 0 for passive. The device can send me also like "0140101000000".

Is there anything like that for this function?

like image 543
Fer Avatar asked Oct 27 '25 05:10

Fer


1 Answers

There is no wildcard character in custom date and time format that it can parse every possible character in your string.

You can add your format the first character of your string like;

string s = "1140421164500";
Console.WriteLine(DateTime.ParseExact(s, s[0] + "yyMMddHHmmss", 
                  CultureInfo.InvariantCulture));

Output will be;

4/21/2014 4:45:00 PM

Here a demonstration.

like image 69
Soner Gönül Avatar answered Oct 29 '25 20:10

Soner Gönül