帮助我如何使用Linq或任何简单方法将字符串中字符串日期的一部分与C#.NET中的确切日期时间进行比较?
示例:
// 10/23/2013 03:43:56 PM
string fileImageName = "Picture_MIGA1_2013_10_23_15_43_56.png";
答案 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();