C#中遍历各类数据集合的方法,这里自己做下总结:
1.枚举类型
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中的元素都是同一数据类型。
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中的行和列
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查询,然后再对查询结果进行遍历。
foreach (DataRow dr in dataSet.Tables[ 0 ].Select( " MONTH>6 AND MONTH<12 " ))
{
// 获取行中某个字段(列)的数据
ary.Add(dr[ " ID " ].ToString());
}
6.遍历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的名称和值全部获取出来了。