日期連貫計算

 

需求:從選中的日期列表中,合併日期連貫的日期,組成DateSpans對象的StartDate和EndDate屬性,造成新的對象List<DateSpans>,代碼和結果截圖以下:spa

 

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Linq;
 4 
 5 namespace CalcDateRange
 6 {
 7     class Program
 8     {
 9         static void Main(string[] args)
10         {
11             List<DateSpans> lstDateSpans = new List<DateSpans>();
12 
13             //選中的日期列表
14             List<DateTime> dates = new List<DateTime> {
15                 new DateTime(2017,9,2),new DateTime(2017,9,1),new DateTime(2017,9,5),new DateTime(2017,9,7)
16                 ,new DateTime(2017,9,8),new DateTime(2017,9,8)
17             };
18 
19             //把日期按從小到大排序
20             dates = dates.OrderBy(p => p.Date).ToList();
21 
22             if (dates.Count > 0)
23             {
24                 Dictionary<DateTime, DateTime> timeSpans = new Dictionary<DateTime, DateTime>();
25                 DateTime previous = DateTime.MinValue;
26                 DateTime current = DateTime.MinValue;
27                 DateTime currentKey = dates[0];
28                 DateSpans ds = new DateSpans();
29 
30                 for (int i = 0; i < dates.Count; i++)
31                 {
32                     if (!timeSpans.ContainsKey(currentKey))
33                     {
34                         timeSpans.Add(currentKey, DateTime.MinValue);
35                     }
36                     if (i > 0)
37                     {
38                         previous = dates[i - 1];
39                     }
40                     current = dates[i];
41                     if (previous != DateTime.MinValue && current.Subtract(previous).Days > 1)
42                     {
43                         timeSpans[currentKey] = previous;
44                         currentKey = current;
45                         timeSpans.Add(currentKey, DateTime.MinValue);
46                     }
47 
48                     if (i == dates.Count - 1)
49                     {
50                         timeSpans[currentKey] = current;
51                     }
52                 }
53                 if (timeSpans.Count > 0)
54                 {
55                     foreach (var item in timeSpans)
56                     {
57                         ds = new DateSpans();
58                         ds.StartDate = item.Key;
59                         ds.EndDate = item.Value;
60                         lstDateSpans.Add(ds);
61 
62                         Console.WriteLine(string.Format("Start Date:{0} End Date:{1}", item.Key.ToShortDateString(), item.Value.ToShortDateString()));
63                     }
64                 }
65             }
66 
67             Console.ReadKey();
68         }
69 
70         class DateSpans
71         {
72             public DateTime StartDate { get; set; }
73             public DateTime EndDate { get; set; }
74         }
75     }
76 }

 運行結果:
  
相關文章
相關標籤/搜索