1. 程式人生 > >【C#】遍歷各類資料集合的方法

【C#】遍歷各類資料集合的方法

    1、列舉型別

    //遍歷列舉型別Sample的各個列舉名稱 
    foreach (string sp in Enum.GetNames(typeof(Sample))) 
    { 
        ary.Add(sp); 
    } 
    //遍歷列舉型別Sample的各個列舉值 
    foreach (string sp in Enum.GetValues(typeof(Sample))) 
    { 
        ary.Add(sp); 
    } 

    2、遍歷ArryList(Queue、Stack)

    這裡以string為例,當然ArrayList中的元素可以是任何資料型別,遍歷時須確認ArrayList中的元素都是同一資料型別

    //遍歷元素為string型別的佇列 
    foreach (string text in arraylist) 
    { 
        ary.Add(text); 
    } 

    此外遍歷Queue佇列和Stack堆疊的方式與ArryList基本相同,都可以使用foreach來迴圈遍歷,只不過一個是先進先出另一個是先進後出

    ArrayList list = new ArrayList();
    //for遍歷
    for (int i = 0; i < list.Count; i++)
    {
        SE se = (SE)list[i];
        Console.WriteLine(se.Name);
    }
    //foreach遍歷
    foreach (Object obj in list)
    {
        SE se = (SE)list[i];
        Console.WriteLine(se.Name);
    }

    3、Winform窗體中的控制元件

    //遍歷尋找主窗體中的控制元件,並將符合條件的控制元件從窗體上去除 
    foreach (Control ctl in this.Controls) 
    { 
        //獲取並判斷控制元件型別或控制元件名稱 
        if (ctl.GetType().Name.Equals("ListBox") || ctl.Name.Equals("listBox1")) 
        this.Controls.Remove(ctl); 
    } 

    4、HashTable雜湊表

    DictionaryEntry類需要引用System.Collections

    //遍歷完整雜湊表中的鍵和值 
    foreach (DictionaryEntry item in hashTable) 
    { 
        ary.Add("雜湊鍵:"+item.Key+",雜湊值:"+item.Value.ToString()); 
    } 
    //此外還可以單獨遍歷雜湊表中的鍵或值。 
    
    //只遍歷雜湊表中的鍵 
    foreach (string key in hashTable.Keys) 
    { 
        ary.Add("雜湊鍵:" + key); 
    }
    
    //只遍歷雜湊表中的值 
    foreach (string value in hashTable.Values) 
    { 
        ary.Add("雜湊值:" + value); 
    } 

    5、遍歷DataSet和DataTable中的行和列

    //遍歷DataSet中的表 
    foreach (DataTable dt in dataSet.Tables) 
    { 
        ary.Add("表名:" + dt.TableName.ToString()); 
    } 
    
    //遍歷DataSet中預設第一個表中的行 
    foreach (DataRow dr in dataSet.Tables[0].Rows) 
    { 
        //獲取行中某個欄位(列)的資料 
        ary.Add(dr["ID"].ToString()); 
    } 
    
    //遍歷DataSet中預設第一個表中的列 
    foreach (DataColumn col in dataSet.Tables[0].Columns) 
    { 
        ary.Add("列名:"+col.ColumnName); 
    } 

    DataTable遍歷行和列的方法和DataSet類似,只是將dataSet.Tables[0]換成具體某張表就可以了,另外還可以對DataTable表進行SQL查詢,然後再對查詢結果進行遍歷

    //遍歷DataSet中表SELECT執行查詢條件後的結果 
    foreach (DataRow dr in dataSet.Tables[0].Select(" MONTH>6 AND MONTH<12 ")) 
    { 
        //獲取行中某個欄位(列)的資料 
        ary.Add(dr["ID"].ToString()); 
    } 

    6、遍歷DataGridView中的行

    //遍歷DataGridView中的行 
    foreach (DataGridViewRow dr in dataGridView1.Rows) 
    { 
        //獲取行中某個欄位(列)的資料 
        ary.Add(dr.Cells["ID"].ToString()); 
    } 

    7、遍歷ListBOX和ComboBox中的item

    一般foreach遍歷只能遍歷到ListBOX和ComboBox裡item的名稱,完整遍歷需要在繫結item的時候新增的item資料是個二元屬性自定義類的物件,將物件中一個屬性的名稱作為DisplayMember(item名),另一個作為DisplayValue(item值)。這樣在遍歷的時候就可以把ListBOX和ComboBox中的item的名稱和值全部獲取出來了

    8、List<T>

    //for遍歷
    for (int i = 0; i < list.Count; i++)
    {
        //遍歷時不需要型別轉換
        Console.WriteLine(list[i]);
    }
    
    //foreach遍歷
    foreach (SE obj in list)
    {
        //遍歷時不需要型別轉換
        Console.WriteLine(obj);
    }

    9、Dictionary<K,V>

    //遍歷Values
    foreach (SE se in list.Values)
    {
        //遍歷時不需要型別轉換
        Console.WriteLine(se);
    }
     
    //同時遍歷
    foreach (KeyValuePair en in list)
    {
        Console.WriteLine(en.Key);
        Console.WriteLine(en.Value.Name);
    }
    //KeyValuePair是一個泛型結構