2016-07-21 111 views
-2

我有一個類和方法通過C#循環收藏

public class Datas 
    { 
     public string Name { get; set; } 
     public int Value { get; set; } 
    } 
public void Funnel() 
    { 
     string commandText = "select sc.stagename, count(cs.stages_id) as StageCount from currentstage cs inner join stagesconfig sc on cs.stages_id = sc.stages_id group by cs.stages_id,sc.stagename"; 


     string constrings = WebConfigurationManager.ConnectionStrings["Data"].ToString(); 

     SqlConnection myConn = new SqlConnection(constrings); 
     SqlCommand myComm = new SqlCommand(commandText, myConn); 

     myConn.Open(); 
     List<Datas> fruitinfo = new List<Datas>(); 

     SqlDataReader reader = myComm.ExecuteReader(); 
     if (reader.HasRows) 
     { 
      while (reader.Read()) 
      { 
       fruitinfo.Add(new Datas 
       { 
        Name = reader.GetValue(0).ToString(), 
        Value = Convert.ToInt32(reader.GetValue(1)) 
       }); 

      } 

     } 

你怎麼遍歷fruitinfo列表保存它的形式array.the數組必須與此類似form.intended更換項目在括號內的數據與fruitinfo循環列表

Data = new Data(new object[] 
       { 
        new object[] { "Website visits", 10000 }, 
        new object[] { "Downloads", 5000 }, 
        new object[] { "Requested price list", 2000 }, 
        new object[] { "Invoice sent", 1000 }, 
        new object[] { "Finalized", 500 } 
       }), 
+4

爲什麼你需要這個醜陋的'對象[]'呢? –

回答

1
var myArray = fruitinfo.Select(d => new object[] { d.Name, d.Value }).ToArray(); 
+2

你在哪裏快7秒... – smoksnes

2
var myArray = fruitinfo.Select(x => new object[] { x.Name, x.Value }).ToArray(); 

並與您的Data -obje使用它克拉。

Data = new Data(myArray); 
+0

完美工作...謝謝 –

0

我不太確定爲什麼你需要產生一個匿名對象數組,但你可以使用字典。

private static void Funnel() 
    { 
     var datas = new List<Datas> 
         { 
          new Datas { Name = "Website visits", Value = 10000 }, 
          new Datas { Name = "Downloads", Value = 5000 }, 
          new Datas { Name = "Requested price list", Value = 2000 }, 
          new Datas { Name = "Invoice sent", Value = 1000 }, 
          new Datas { Name = "Finalized", Value = 500 } 
         }; 

     var data = datas.ToDictionary(datas1 => datas1.Name, datas1 => datas1.Value); 
     foreach (var item in data) 
     { 
      Console.WriteLine(string.Format("{0}, {1}",item.Key, item.Value)); 
     } 

     var arry = data.ToArray(); 
     foreach (var item in arry) 
     { 
      Console.WriteLine(string.Format("{0}, {1}", item.Key, item.Value)); 
     } 
    } 

Output