转:C#中遍历各类数据集合的方法


转自:

http://www.cnblogs.com/youuuu/archive/2011/06/25/2090117.html

C#中遍历各类数据集合的方法

1.枚举类型

//遍历枚举类型Sample的各个枚举名称
foreach(stringspinEnum.GetNames(typeof(Sample)))
{
ary.Add(sp);
}
//遍历枚举类型Sample的各个枚举值
foreach(stringspinEnum.GetValues(typeof(Sample)))
{
ary.Add(sp);
}

2.遍历ArrayList(Queue、Stack)

这里以string为例,当然ArrayList中的元素可以是任何数据类型,遍历时须确认ArrayList中的元素都是同一数据类型。

//遍历元素为string类型的队列
foreach(stringtextinarraylist)
{
ary.Add(text);
}

此外遍历Queue队列和Stack堆栈的方式与ArrayList基本相同,都可以使用foreach来循环遍历,只不过一个是先进先出另一个是先进后出罢了。

3.Winform窗体中的控件

//遍历寻找主窗体中的控件,并将符合条件的控件从窗体上去除
foreach(Controlctlinthis.Controls)
{
//获取并判断控件类型或控件名称
if(ctl.GetType().Name.Equals("ListBox")||ctl.Name.Equals("listBox1"))
this.Controls.Remove(ctl);
}

4.HashTable哈希表

DictionaryEntry类需要引用System.Collections

//遍历完整哈希表中的键和值
foreach(DictionaryEntryiteminhashTable)
{
ary.Add(
"哈希键:"+item.Key+",哈希值:"+item.Value.ToString());
}

此外还可以单独遍历哈希表中的键或值。

//只遍历哈希表中的键
foreach(stringkeyinhashTable.Keys)
{
ary.Add(
"哈希键:"+key);
}

//只遍历哈希表中的值
foreach(stringvalueinhashTable.Values)
{
ary.Add(
"哈希值:"+value);
}

5.遍历DataSet和DataTable中的行和列

//遍历DataSet中的表
foreach(DataTabledtindataSet.Tables)
{
ary.Add(
"表名:"+dt.TableName.ToString());

}
//遍历DataSet中默认第一个表中的行
foreach(DataRowdrindataSet.Tables[0].Rows)
{
//获取行中某个字段(列)的数据
ary.Add(dr["ID"].ToString());
}
//遍历DataSet中默认第一个表中的列
foreach(DataColumncolindataSet.Tables[0].Columns)
{
ary.Add(
"列名:"+col.ColumnName);
}

DataTable遍历行和列的方法和DataSet类似,只是将dataSet.Tables[0]换成具体某张表就可以了。

另外还可以对DataTable表进行SQL查询,然后再对查询结果进行遍历。

//遍历DataSet中表SELECT执行查询条件后的结果
foreach(DataRowdrindataSet.Tables[0].Select("MONTH>6ANDMONTH<12"))
{
//获取行中某个字段(列)的数据
ary.Add(dr["ID"].ToString());
}

6.遍历DataGridView中的行

//遍历DataGridView中的行
foreach(DataGridViewRowdrindataGridView1.Rows)
{
//获取行中某个字段(列)的数据
ary.Add(dr.Cells["ID"].ToString());
}

7.遍历ListBOX和ComboBox中的item

一般foreach遍历只能遍历到ListBOX和ComboBox里item的名称,完整遍历需要在绑定item的时候添加的item数据是个二元属性自定义类的对象,将对象中一个属性的名称作为DisplayMember(item名),另一个作为DisplayValue(item值)。这样在遍历的时候就可以把ListBOX和ComboBox中的item的名称和值全部获取出来了。

优质内容筛选与推荐>>
1、Web网站服务(Apache的安装)
2、机器学习笔记之信息熵、信息增益和决策树(ID3算法)
3、SQLServer基础SQL脚本之GroupBy
4、Shell编程入门实例
5、别一上来就提微服务,请问你懂RPC吗


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号





    联系我们

    欢迎来到TinyMind。

    关于TinyMind的内容或商务合作、网站建议,举报不良信息等均可联系我们。

    TinyMind客服邮箱:support@tinymind.net.cn