1 publicstring GetJfmxBzsj(DataTable dt)
2 {
3 var result ="";
4 if (dt ==null)
5 return result;
6 elseif (dt.Rows.Count ==1)
7 {
8 result = GetSfyf(dt.Rows[0]["jfqsrq"].ToString(), dt.Rows[0]["jfzzrq"].ToString());
9 }
10 else
11 {
12 int i =0;
13 while (true)
14 {
15 var kssj = Convert.ToDateTime(dt.Rows[i]["jfqsrq"]);
16 var jssj = Convert.ToDateTime(dt.Rows[i]["jfzzrq"]);
17 for (; i < dt.Rows.Count -1; i++)
18 {
19 var temp = Convert.ToDateTime(dt.Rows[i +1]["jfqsrq"]);
20 //同年的时候 终止时间 是下条记录的起始时间的上月 则合并 不同年 上年的月份为12 下年为1月 则合并
21 if ((jssj.Year == temp.Year && jssj.Month +1== temp.Month) || (jssj.Year +1== temp.Year && jssj.Month ==12&& temp.Month ==1))
22 {
23 jssj = Convert.ToDateTime(dt.Rows[i +1]["jfzzrq"]);
24 }
25 else
26 {
27 result +=""+ GetSfyf(kssj.ToString(), jssj.ToString());
28 i = i +1;
29 break;
30 }
31 }
32 if (i == dt.Rows.Count -1) //最后一列
33 {
34 result +=""+ GetSfyf(dt.Rows[i]["jfqsrq"].ToString(), dt.Rows[i]["jfzzrq"].ToString());
35 break;
36 }
37 }
38 }
39 return result;
40 }
41
42
43 ///<summary>
44 /// 获取缴费月份段
45 ///</summary>
46 ///<param name="start">开始时间</param>
47 ///<param name="end">结束时间</param>
48 ///<returns></returns>
49 publicstring GetSfyf(string start, string end)
50 {
51 if (start ==""|| end =="")
52 return"";
53 var s = DateTime.Parse(start);
54 var e = DateTime.Parse(end);
55 if (s.Year == e.Year && s.Month != e.Month)
56 {
57 return e.Year.ToString().Trim() +"年"+"("+ s.Month.ToString().Trim() +"-"+ e.Month.ToString().Trim() +")月";
58 }
59 elseif (s.Year == e.Year && s.Month == e.Month)
60 {
61 return s.ToString("yyyy年MM月");
62 }
63 elseif (s.Year != e.Year)
64 {
65 return s.ToString("yyyy年MM月") +"至"+ e.ToString("yyyy年MM月");
66 }
67 return"";
68 }