首先,您需要定义CultureInfo你将被用于所有文本转换。在你的例子看起来像美国,所以让我们使用那个。
CultureInfo culture = new CultureInfo("en-us");
然后,您需要将这些文本行解析为DateTimes,以便您可以使用它们。 鲜明将确保有没有重复和排序依据将整理与默认的日期时间比较(升序)结果
//Use full path instead of "input.txt"
IEnumerable<DateTime> datesInFile = File.ReadAllLines(@"input.txt")
.Select(s => DateTime.Parse(s, culture))
.Distinct()
.OrderBy(d => d);
一个星期的日子可以通过迭代7天开始指定的日期来枚举。
//This date should probably come from somewhere else
DateTime startDate = new DateTime(2013, 04, 08);
IEnumerable<DateTime> datesInWeek = Enumerable.Range(0, 6)
.Select(d => startDate.Date.AddDays(d));
由于每天需要所有时间戳,因此需要按日期对它们进行分组。 ToDictionary将期望lambda表达式:第一个将是键(日期)和第二个值(与当天的时间戳列表)。
Dictionary<DateTime, IEnumerable<DateTime>> result = datesInWeek
.ToDictionary(
d => d,
d => datesInFile.Where(dif => d.Date == dif.Date));
最后你可以把你的结果和它们聚集(在指定的文化,当然格式)
string outputText = result.Aggregate("",
(current, pair) => current +
pair.Key.ToString("ddd MMM d", culture) +
Environment.NewLine +
String.Join(Environment.NewLine, pair.Value.Select(
d => d.ToString("MM/dd/yyyy hh:mm:ss tt", culture))) +
Environment.NewLine);
紧凑型:
CultureInfo culture = new CultureInfo("en-us");
IEnumerable<DateTime> datesInFile = File
.ReadAllLines(@"C:\Temp\input.txt")
.Select(s => DateTime.Parse(s, culture))
.Distinct()
.OrderBy(d => d);
string outputText = Enumerable
.Range(0, 6)
.Select(d => new DateTime(2013,04,08).Date.AddDays(d))
.ToDictionary(d => d, d => datesInFile.Where(dif => d.Date == dif.Date))
.Aggregate("", (current, pair) => current + pair.Key.ToString("ddd MMM d", culture) + Environment.NewLine +
String.Join(Environment.NewLine, pair.Value.Select(d => d.ToString("MM/dd/yyyy hh:mm:ss tt", culture))) +
Environment.NewLine);