ChartData.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace wispro.sp.share
  8. {
  9. public class ChartData
  10. {
  11. public string type { get; set; }
  12. public string CustomerType { get; set; }
  13. public string year { get; set; }
  14. public string CustomerYear { get; set; }
  15. public double value { get; set; }
  16. }
  17. public class ChartDatas
  18. {
  19. public List<ChartData> Datas { get; set; }
  20. public string Title { get; set; }
  21. public string ATitle { get; set; }
  22. public string BTitle { get; set; }
  23. public List<string> GetYear()
  24. {
  25. List<string> retColumns = new List<string>();
  26. foreach (var cData in Datas)
  27. {
  28. if (!retColumns.Contains(cData.year))
  29. {
  30. retColumns.Add(cData.year);
  31. }
  32. }
  33. retColumns.Sort();
  34. return retColumns;
  35. }
  36. public List<string> GetSeries()
  37. {
  38. List<string> retColumns = new List<string>();
  39. foreach (var cData in Datas)
  40. {
  41. if (!retColumns.Contains(cData.type))
  42. {
  43. retColumns.Add(cData.type);
  44. }
  45. }
  46. return retColumns;
  47. }
  48. public DataTable GetTableData()
  49. {
  50. DataTable retTable = new DataTable();
  51. List<string> Columns = GetYear();
  52. retTable.Columns.Add(ATitle);
  53. foreach (string col in Columns)
  54. {
  55. retTable.Columns.Add(col);
  56. }
  57. foreach (var cData in Datas)
  58. {
  59. int iIndex = Columns.IndexOf(cData.year);
  60. DataRow row = null;
  61. foreach (DataRow temRow in retTable.Rows)
  62. {
  63. if (temRow[ATitle].ToString() == cData.type)
  64. {
  65. row = temRow;
  66. break;
  67. }
  68. }
  69. if (row != null)
  70. {
  71. row[cData.year] = cData.value;
  72. }
  73. else
  74. {
  75. row = retTable.NewRow();
  76. row[ATitle] = cData.type;
  77. row[cData.year] = cData.value;
  78. retTable.Rows.Add(row);
  79. }
  80. }
  81. return retTable;
  82. }
  83. }
  84. }