我需要在C#中使用正则表达式验证日期格式。
格式为:"YYYYMMDD"
答案 0 :(得分:16)
正则表达式不适合此任务。例如,很难编写与有效日期“20080229”匹配但不是无效日期“20100229”的正则表达式。
相反,您应该使用格式字符串"yyyyMMdd"
的{{3}}。这是一个例子:
string s = "20100229";
DateTime result;
if (!DateTime.TryParseExact(
s,
"yyyyMMdd",
CultureInfo.InvariantCulture,
DateTimeStyles.AssumeUniversal,
out result))
{
Console.WriteLine("Invalid date entered.");
};
答案 1 :(得分:6)
好的,这是我制作过的最漂亮的正则表达式。这说明了自1582年以来所有闰年的飞跃。它还处理每四个世纪的非飞跃。例如,1600是飞跃,但1700不是可以被4整除。我在1582年到9999之间的所有日子都进行了测试。
var yyyymmdd = new RegExp("^(?:(?:(?:(?:(?:[13579][26]|[2468][048])00)|(?:[0-9]{2}(?:(?:[13579][26])|(?:[2468][048]|0[48]))))(?:(?:(?:09|04|06|11)(?:0[1-9]|1[0-9]|2[0-9]|30))|(?:(?:01|03|05|07|08|10|12)(?:0[1-9]|1[0-9]|2[0-9]|3[01]))|(?:02(?:0[1-9]|1[0-9]|2[0-9]))))|(?:[0-9]{4}(?:(?:(?:09|04|06|11)(?:0[1-9]|1[0-9]|2[0-9]|30))|(?:(?:01|03|05|07|08|10|12)(?:0[1-9]|1[0-9]|2[0-9]|3[01]))|(?:02(?:[01][0-9]|2[0-8])))))$");
另一个使用短划线的版本
var yyyyDashMmDashDd = new RegExp("^(?:(?:(?:(?:(?:[13579][26]|[2468][048])00)|(?:[0-9]{2}(?:(?:[13579][26])|(?:[2468][048]|0[48]))))-(?:(?:(?:09|04|06|11)-(?:0[1-9]|1[0-9]|2[0-9]|30))|(?:(?:01|03|05|07|08|10|12)-(?:0[1-9]|1[0-9]|2[0-9]|3[01]))|(?:02-(?:0[1-9]|1[0-9]|2[0-9]))))|(?:[0-9]{4}-(?:(?:(?:09|04|06|11)-(?:0[1-9]|1[0-9]|2[0-9]|30))|(?:(?:01|03|05|07|08|10|12)-(?:0[1-9]|1[0-9]|2[0-9]|3[01]))|(?:02-(?:[01][0-9]|2[0-8])))))$");
我喜欢这几乎适用于所有语言,只要它们支持正则表达式。虽然使用特定语言的日期解析器可能更明智,但我认为这显示了正则表达式的强大和优雅。
如果你想看到它,下面是Regexper中带有斜杠的image模式。
答案 2 :(得分:2)
考虑使用DateTime.TryParseExact来验证日期。 您可以使用该方法同时验证和读取DateTime值。
例如:
DateTime dateValue;
if (DateTime.TryParseExact(dateString, "yyyyMMdd", CultureInfo.InvariantCulture, DateTimeStyles.None, out dateValue))
{
//Parsed Successfully
}