天天看點

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