使用LinQ将String中的stringdate的一部分与C#.NET中的datetime进行比较

时间:2013-10-23 14:01:49

标签: c# .net linq datetime

帮助我如何使用Linq或任何简单方法将字符串中字符串日期的一部分与C#.NET中的确切日期时间进行比较?

示例:

//  10/23/2013 03:43:56 PM
string fileImageName = "Picture_MIGA1_2013_10_23_15_43_56.png";

1 个答案:

答案 0 :(得分:4)

使用DateTime.TryParseExact(除其他外):

DateTime toCompare = new DateTime(2013, 10, 23, 15, 43, 56);
string fileImageName = "Picture_MIGA1_2013_10_23_15_43_56.png";
var tokens = Path.GetFileNameWithoutExtension(fileImageName).Split('_');
// take last 6 because there are the datetime informations in the filename
var dateTokens = tokens.Skip(Math.Max(0, tokens.Length - 6)).Take(6).ToArray(); 
if (dateTokens.Length == 6)
{
    DateTime dt;
    DateTime.TryParseExact(
        string.Join("_", dateTokens),
        "yyyy_MM_dd_HH_mm_ss",
        CultureInfo.InvariantCulture,
        DateTimeStyles.None,
        out dt);
    bool isSame = toCompare == dt;  // true
}

修改

  

如何使用LinQ查询编写

你还没有提到你有什么类型的cllection。因此,为了简单起见,我使用List<string>显示了一个示例:

var fileNames = new List<string>() { "Picture_MIGA1_2013_10_23_15_43_56.png" };
List<string> allMatching = fileNames
.Where(fn =>
{
    var tokens = Path.GetFileNameWithoutExtension(fn).Split('_');
    var dateTokens = tokens.Skip(Math.Max(0, tokens.Length - 6)).Take(6).ToArray();
    if (dateTokens.Length == 6)
    {
        DateTime dt;
        DateTime.TryParseExact(
            string.Join("_", dateTokens),
            "yyyy_MM_dd_HH_mm_ss",
            CultureInfo.InvariantCulture,
            DateTimeStyles.None,
            out dt);
        return toCompare == dt;
    }
    return false;
}).ToList();