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


    C#中遍历各类数据集合的方法,这里自己做下总结: 

    //遍历枚举类型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); 

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

  • 相关阅读:
    复制构造函数
    c++运算符优先级
    std::condition_variable(二)
    std::condition_variable
    std::unique_lock
    std::lock_guard
    Oracle 11gR2 11.2.0.1 ( 11.2.0.1的BUG?):ohasd不能正常启动:ioctl操作:npohasd的问题:【chmod a+wr /var/tmp/.oracle/npohasd】
    bat、cmd、dos窗口:后台调用,不显示黑色的控制台dos(命令行)窗口
    Ubuntu 安装 Oracle11gR2:'install' of makefile '/home/oracle/app/oracle/product/11.2.0/dbhome_1/ctx/lib/ins_ctx.mk'
    Ubuntu 10.04 安装 Oracle11gR2
  • 原文地址:https://www.cnblogs.com/sjqq/p/6385263.html
Copyright © 2020-2023  润新知