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.遍歷ArrayList(Queue、Stack)

這裏以string爲例,當然ArrayList中的元素可以是任何數據類型,遍歷時須確認ArrayList中的元素都是同一數據類型。

            //遍歷元素爲string類型的隊列
            foreach (string text in arraylist)
            {
                ary.Add(text);
            }

此外遍歷Queue隊列和Stack堆棧的方式與ArrayList基本相同, 都可以使用foreach來循環遍歷,只不過一個是先進先出另一個是先進後出罷了。

 

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的名稱和值全部獲取出來了

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章