我有一个List<string>
日期。
我的清单是:
{"01/01/2013","10/01/2013","20/01/2013"}
我想对列表进行排序,如下所示:
{"20/01/2013","10/01/2013","01/01/2013"}
我怎样才能做到这一点?
使用 linq:
var list = new List<string> {"01/01/2013", "10/01/2013", "20/01/2013"};
var orderedList = list.OrderByDescending(x => DateTime.Parse(x)).ToList();
更新(根据评论中的问题):
您可以这样处理无效日期(无效日期被视为default(DateTime)
):
var list = new List<string> { "01/01/2013", "10/01/2013", "N/A" , "20/01/2013" };
var orderedList2 = list.OrderByDescending(x =>
{
DateTime dt;
DateTime.TryParse(x, out dt);
return dt;
});
或者,如果您想将无效的日期时间作为列表中的第一项:
var orderedList3 = list.OrderByDescending(x =>
{
DateTime dt;
if (!DateTime.TryParse(x, out dt)) return DateTime.MaxValue;
return dt;
});
您还可以过滤掉无效的日期:
var filteredList = list.Where(x =>
{
DateTime dt;
return DateTime.TryParse(x, out dt);
}).Select(DateTime.Parse).OrderByDescending(x => x);
甚至更好:
var filteredList = list.Select(x =>
{
DateTime dt;
return new {valid = DateTime.TryParse(x, out dt), date = dt};
}).Where(x => x.valid).Select(x => x.date).OrderByDescending(x => x);
您不应该使用数据的字符串表示形式——我们都生活在面向对象的世界中 :)
最好的方法是将这些字符串转换为实际的 DateTime 对象并通过 linq 以相反的顺序对它们进行排序:
var dates = Array.ConvertAll(dateStrings, x => DateTime.Parse(x));
return dates.OrderByDesc(x => x);
另一种方法是实现自定义排序功能,请参阅此链接。然后你只需在排序函数中使用它:
DateAsStringComparer myComparer = new DateAsStringComparer();
dateStrings.Sort(myComparer);
试试这个:
List<string> s = new List<string>() { "01/01/2013", "10/01/2013", "20/01/2013" };
var d = s.OrderByDescending(i => DateTime.ParseExact(i, "dd/MM/yyyy", null));
为什么要使用List<string>
而不是List<DateTime>
?
List<DateTime> dates = ...
dates.OrderByDescending(c => c).ToList();
因为它们是英国/澳大利亚格式(日/月/年),您可以使用以下方式对它们进行排序OrderByDescending
:
List<string> dates = new List<string>() { "01/01/2013", "10/01/2013", "20/10/2013" };
foreach (var date in dates.OrderByDescending(x => x))
Console.WriteLine(date);
我个人会DateTime
先将它们转换为对象..
要将自定义格式的 DateTime 字符串转换string
为统一格式的,可以采用以下简单和safe
片段。
string formatStr = "yyyyMMddHHmmss";
string result = Convert.ToDateTime(inputStr).ToString(formatStr);
在代码中,formatStr
可以是DateTime
类可以接受的任何可能的形式,您可以将其设置为您需要的格式,这里您可以使用dd/MM/yyyy
与您的目标格式字符串匹配的格式,例如“20/01/2013”。
因此,对于您的情况,代码可以很简单,如下所示:
List<string> list = new List<string> { "01/01/2013", "10/01/2013", "20/01/2013" };
var listAfterSorting = list.OrderByDescending(t =>
Convert.ToDateTime(t).ToString("dd/MM/yyyy")
.ToList());
虽然在某些情况下,使用ParseExact
解析数据时间字符串,它会抛出错误/异常String was not recognized as a valid DateTime
,在这种情况下,如果你转向使用TryParseExact
,结果可能是default(DateTime)
= 1/1/0001 12:00:00 AM
,因为解析失败。因此,我不推荐ParseExact
or TryParseExact
。