2012-11-15 36 views
1

我有一個數據表和區間大小爲10DataTable的基於時間添加行間隔尺寸

輸入表:

DateTime ChNo Data 
-------------------------- 
6/10 10:10 1  0.1 
6/10 10:20 1  0.1 
6/10 11:05 2  0.1 
6/10 11:06 2  0.1 
6/10 11:07 2  0.1 
6/10 11:08 2  0.1 
6/10 11:09 2  0.1 
6/10 11:10 2  0.1 
6/10 11:11 2  0.1 
6/10 11:12 2  0.1 
6/10 11:13 2  0.1 

我需要基於間隔大小如上表進行轉換,如我上面解釋的。如果間隔大小是10我的目標表應該看起來像

DateTime ChNo Data 
-------------------------- 
6/10 10:10 1  0.1 
6/10 10:20 1  0.1 
6/10 11:10 2  0.6 -----> sum of intervals from 11:05 to 11:10 
6/10 11:13 2  0.3 -----> sum of intervals from 11:11 to 11:13 

是什麼,從而獲得所需的最佳方式輸出像上面,用1 inqs

謝謝, Murali。

回答

1

我還沒有找到Linq解決方案,但我可以爲您提供一個程序化解決方案。請注意,我使用完整的DateTime表示法進行分析,而不是因爲沒有年份。檢查代碼:

   //DataTable initialisation 
       dt = new DataTable(); 
       dt.Columns.Add("Column1"); 
       dt.Columns.Add("Column2"); 
       dt.Columns.Add("Column3"); 


       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 10:10"), 1, 0.1 }); 
       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 10:20"), 1, 0.1 }); 
       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 11:05"), 2, 0.1 }); 
       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 11:06"), 2, 0.1 }); 
       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 11:07"), 2, 0.1 }); 
       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 11:08"), 2, 0.1 }); 
       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 11:09"), 2, 0.1 }); 
       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 11:10"), 2, 0.1 }); 
       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 11:11"), 2, 0.1 }); 
       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 11:12"), 2, 0.1 }); 
       dt.Rows.Add(new object[] { DateTime.Parse("6/10/2012 11:13"), 2, 0.1 }); 


//Method that groups data 
    void GroupByDate() 
    { 
       DateTime startDate = DateTime.Parse(dt.Rows[0].ItemArray[0].ToString()); 
       DateTime endDate = DateTime.Parse(dt.Rows[dt.Rows.Count - 1].ItemArray[0].ToString()); 
       StringBuilder sb = new StringBuilder(); 
       int rowIndex = 0; 
       for (DateTime d = startDate.AddMinutes(-(startDate.Minute - 1) % 10); rowIndex < dt.Rows.Count && d < endDate.AddMinutes(10 - endDate.Minute % 10); d = d.AddMinutes(10)) 
       { 
        double sum = 0; 
        DateTime lastDateInSequence = new DateTime(); 
        for (DateTime md = d;rowIndex < dt.Rows.Count && md < d.AddMinutes(10); md = md.AddMinutes(1)) 
        { 
         DateTime inbetween = DateTime.Parse(dt.Rows[rowIndex].ItemArray[0].ToString()); 
         if (inbetween == md) 
         { 
          sum += double.Parse(dt.Rows[rowIndex].ItemArray[2].ToString()); 
          lastDateInSequence = md; 
          rowIndex++; 
         } 
        } 
        if (sum > 0.0) 
        { 
         // you can add this results to the new DataTable like dt1.Rows.Add(lastDateInSequence.ToString("dd/MM hh:mm"), dt.Rows[rowIndex - 1].ItemArray[1], sum); 
         sb.Append(lastDateInSequence.ToString("dd/MM hh:mm") + " " + dt.Rows[rowIndex - 1].ItemArray[1].ToString() + " " + sum.ToString() + Environment.NewLine); 
        } 
       } 
       MessageBox.Show(sb.ToString()); 
    } 
+0

非常感謝您檢查代碼。 – user1805169

+0

太棒了!它再次感謝你尼克。 – user1805169

+0

沒問題,很高興代碼幫助了你;-) –