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来循环遍历,只不过一个是先进先出另一个是先进后出罢了。


.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());

本文来自网络。

你可能感兴趣的:(C#中的遍历)