11

我正在做一个项目,我正在读取一个文件,该文件可能有两种不同的格式,一种包括日期和时间,另一种不包括。

当我在第一行读取时,我需要检查字符串是否包含日期和时间并读取文件并基于检查以某种方式读取文件。

我猜这将是某种正则表达式,但不知道从哪里开始,也找不到任何相关的东西。

感谢您的任何帮助,您可以提供。

更新 我认为我对我的要求不是很清楚。当我逐行读取日志文件时,该行可能如下所示:

Col1   Col2  Col3  Col4  Col5 

有时这条线可能会作为

Col1  17-02-2013 02:05:00 Col2  Col3  Col4  Col5

当我阅读该行时,我需要检查字符串中是否包含日期和时间字符串。

4

5 回答 5

20

如果已经定义了日期的格式,可以使用Regex来解决。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Text.RegularExpressions;

namespace RegTest
{
    class Program
    {
        static void Main(string[] args)
        {
            string testDate = "3214312402-17-2013143214214";
            Regex rgx = new Regex(@"\d{2}-\d{2}-\d{4}");
            Match mat = rgx.Match(testDate);
            Console.WriteLine(mat.ToString());
            Console.ReadLine();
        }
    }
}
于 2013-02-17T05:55:25.553 回答
5

更新 2:发现使用 DateTime.TryParseExact 是使用正则表达式的更好方法

DateTime myDate;
if (DateTime.TryParseExact(inputString, "dd-MM-yyyy hh:mm:ss", 
    CultureInfo.InvariantCulture, DateTimeStyles.None, out myDate))
{
    //String has Date and Time
}
else
{
    //String has only Date Portion    
}
于 2013-02-17T01:49:10.983 回答
2
   string s = " Subject: Current account balances for 21st December 2017 and 2nd January 2019 mnmnm ";//here is u r sample string

   s = s.ToLower();
   string newStrstr = Regex.Replace(s, " {2,}", " ");//remove more than whitespace
   string newst = Regex.Replace(newStrstr, @"([\s+][-/./_///://|/$/\s+]|[-/./_///://|/$/\s+][\s+])", "/");// remove unwanted whitespace eg 21 -dec- 2017 to 21-07-2017
   newStrstr = newst.Trim();
   Regex rx = new Regex(@"(st|nd|th|rd)");//21st-01-2017 to 21-01-2017
   string sp = rx.Replace(newStrstr, "");
   rx = new Regex(@"(([0-2][0-9]|[3][0-1]|[0-9])[-/./_///://|/$/\s+]([0][0-9]|[0-9]|[1][0-2]|jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec|january|february|march|april|may|june|july|augu|september|october|november|december)[-/./_///:/|/$/\s+][0-9]{2,4})");//a pattern for regex to check date format. For August we check Augu since we replaced the st earlier
   MatchCollection mc = rx.Matches(sp);//look for strings that satisfy the above pattern regex

   List<DateTime> dates=new List<DateTime>(); //Create a list to store the detected dates

   foreach(Match m in mc)
   {
        string s2=Regex.Replace(m.ToString(), "augu", "august");
        dates.Add(DateTime.Parse(s2);
   }
于 2017-12-11T06:00:24.680 回答
-2

使用此方法检查字符串是否为日期:

private bool CheckDate(String date)
{
    try
    {
        DateTime dt = DateTime.Parse(date);
        return true;
    }
    catch
    {
        return false;
    }
}
于 2015-09-30T16:50:05.477 回答
-3

这对我们有用:

如果字符串值是有效的日期时间值,那么它不会给出任何异常:

try
{
    Convert.ToDateTime(string_value).ToString("MM/dd/yyyy");
}

如果字符串值是无效的日期时间值,则会给出异常:

catch (Exception)
{
}
于 2013-09-11T16:07:31.970 回答