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的名称和值全部获取出来了

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值