C#中遍歷各類數(shù)據(jù)集合的方法總結(jié)
更新時(shí)間:2013年05月26日 17:58:05 作者:
C#中遍歷各類數(shù)據(jù)集合的方法,這里自己做下總結(jié):枚舉類型、遍歷ArrayList(Queue、Stack)、Winform窗體中的控件、HashTable哈希表等等,具體祥看下文
C#中遍歷各類數(shù)據(jù)集合的方法,這里自己做下總結(jié):
1.枚舉類型
//遍歷枚舉類型Sample的各個(gè)枚舉名稱
foreach (string sp in Enum.GetNames(typeof(Sample)))
{
ary.Add(sp);
}
//遍歷枚舉類型Sample的各個(gè)枚舉值
foreach (string sp in Enum.GetValues(typeof(Sample)))
{
ary.Add(sp);
}
2.遍歷ArrayList(Queue、Stack)
這里以string為例,當(dāng)然ArrayList中的元素可以是任何數(shù)據(jù)類型,遍歷時(shí)須確認(rèn)ArrayList中的元素都是同一數(shù)據(jù)類型。
//遍歷元素為string類型的隊(duì)列
foreach (string text in arraylist)
{
ary.Add(text);
}
此外遍歷Queue隊(duì)列和Stack堆棧的方式與ArrayList基本相同, 都可以使用foreach來循環(huán)遍歷,只不過一個(gè)是先進(jìn)先出另一個(gè)是先進(jìn)后出罷了。
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());
}
此外還可以單獨(dú)遍歷哈希表中的鍵或值。
//只遍歷哈希表中的鍵
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中默認(rèn)第一個(gè)表中的行
foreach (DataRow dr in dataSet.Tables[0].Rows)
{
//獲取行中某個(gè)字段(列)的數(shù)據(jù)
ary.Add(dr["ID"].ToString());
}
//遍歷DataSet中默認(rèn)第一個(gè)表中的列
foreach (DataColumn col in dataSet.Tables[0].Columns)
{
ary.Add("列名:"+col.ColumnName);
}
DataTable遍歷行和列的方法和DataSet類似,只是將dataSet.Tables[0]換成具體某張表就可以了。
另外還可以對(duì)DataTable表進(jìn)行SQL查詢,然后再對(duì)查詢結(jié)果進(jìn)行遍歷。
//遍歷DataSet中表SELECT執(zhí)行查詢條件后的結(jié)果
foreach (DataRow dr in dataSet.Tables[0].Select(" MONTH>6 AND MONTH<12 "))
{
//獲取行中某個(gè)字段(列)的數(shù)據(jù)
ary.Add(dr["ID"].ToString());
}
6.遍歷DataGridView中的行
//遍歷DataGridView中的行
foreach (DataGridViewRow dr in dataGridView1.Rows)
{
//獲取行中某個(gè)字段(列)的數(shù)據(jù)
ary.Add(dr.Cells["ID"].ToString());
}
7.遍歷ListBOX和ComboBox中的item
一般foreach遍歷只能遍歷到ListBOX和ComboBox里item的名稱,完整遍歷需要在綁定item的時(shí)候添加的item數(shù)據(jù)是個(gè)二元屬性自定義類的對(duì)象,將對(duì)象中一個(gè)屬性的名稱作為DisplayMember(item名),另一個(gè)作為DisplayValue(item值)。這樣在遍歷的時(shí)候就可以把ListBOX和ComboBox中的item的名稱和值全部獲取出來了。
1.枚舉類型
復(fù)制代碼 代碼如下:
//遍歷枚舉類型Sample的各個(gè)枚舉名稱
foreach (string sp in Enum.GetNames(typeof(Sample)))
{
ary.Add(sp);
}
//遍歷枚舉類型Sample的各個(gè)枚舉值
foreach (string sp in Enum.GetValues(typeof(Sample)))
{
ary.Add(sp);
}
2.遍歷ArrayList(Queue、Stack)
這里以string為例,當(dāng)然ArrayList中的元素可以是任何數(shù)據(jù)類型,遍歷時(shí)須確認(rèn)ArrayList中的元素都是同一數(shù)據(jù)類型。
復(fù)制代碼 代碼如下:
//遍歷元素為string類型的隊(duì)列
foreach (string text in arraylist)
{
ary.Add(text);
}
此外遍歷Queue隊(duì)列和Stack堆棧的方式與ArrayList基本相同, 都可以使用foreach來循環(huán)遍歷,只不過一個(gè)是先進(jìn)先出另一個(gè)是先進(jìn)后出罷了。
3.Winform窗體中的控件
復(fù)制代碼 代碼如下:
//遍歷尋找主窗體中的控件,并將符合條件的控件從窗體上去除
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
復(fù)制代碼 代碼如下:
//遍歷完整哈希表中的鍵和值
foreach (DictionaryEntry item in hashTable)
{
ary.Add("哈希鍵:"+item.Key+",哈希值:"+item.Value.ToString());
}
此外還可以單獨(dú)遍歷哈希表中的鍵或值。
//只遍歷哈希表中的鍵
foreach (string key in hashTable.Keys)
{
ary.Add("哈希鍵:" + key);
}
//只遍歷哈希表中的值
foreach (string value in hashTable.Values)
{
ary.Add("哈希值:" + value);
}
5.遍歷DataSet和DataTable中的行和列
復(fù)制代碼 代碼如下:
//遍歷DataSet中的表
foreach (DataTable dt in dataSet.Tables)
{
ary.Add("表名:" + dt.TableName.ToString());
}
//遍歷DataSet中默認(rèn)第一個(gè)表中的行
foreach (DataRow dr in dataSet.Tables[0].Rows)
{
//獲取行中某個(gè)字段(列)的數(shù)據(jù)
ary.Add(dr["ID"].ToString());
}
//遍歷DataSet中默認(rèn)第一個(gè)表中的列
foreach (DataColumn col in dataSet.Tables[0].Columns)
{
ary.Add("列名:"+col.ColumnName);
}
DataTable遍歷行和列的方法和DataSet類似,只是將dataSet.Tables[0]換成具體某張表就可以了。
另外還可以對(duì)DataTable表進(jìn)行SQL查詢,然后再對(duì)查詢結(jié)果進(jìn)行遍歷。
復(fù)制代碼 代碼如下:
//遍歷DataSet中表SELECT執(zhí)行查詢條件后的結(jié)果
foreach (DataRow dr in dataSet.Tables[0].Select(" MONTH>6 AND MONTH<12 "))
{
//獲取行中某個(gè)字段(列)的數(shù)據(jù)
ary.Add(dr["ID"].ToString());
}
6.遍歷DataGridView中的行
復(fù)制代碼 代碼如下:
//遍歷DataGridView中的行
foreach (DataGridViewRow dr in dataGridView1.Rows)
{
//獲取行中某個(gè)字段(列)的數(shù)據(jù)
ary.Add(dr.Cells["ID"].ToString());
}
7.遍歷ListBOX和ComboBox中的item
一般foreach遍歷只能遍歷到ListBOX和ComboBox里item的名稱,完整遍歷需要在綁定item的時(shí)候添加的item數(shù)據(jù)是個(gè)二元屬性自定義類的對(duì)象,將對(duì)象中一個(gè)屬性的名稱作為DisplayMember(item名),另一個(gè)作為DisplayValue(item值)。這樣在遍歷的時(shí)候就可以把ListBOX和ComboBox中的item的名稱和值全部獲取出來了。
您可能感興趣的文章:
- C#遍歷集合與移除元素的方法
- C#常見的幾種集合 ArrayList,Hashtable,List<T>,Dictionary<K,V> 遍歷方法對(duì)比
- C#使用foreach語句遍歷集合類型的方法
- C#使用yield關(guān)鍵字讓自定義集合實(shí)現(xiàn)foreach遍歷的方法
- C#中哈希表(HashTable)用法實(shí)例詳解(添加/移除/判斷/遍歷/排序等)
- C#使用foreach循環(huán)遍歷數(shù)組完整實(shí)例
- C#遍歷文件夾及其子目錄的完整實(shí)現(xiàn)方法
- C#簡(jiǎn)單遍歷指定文件夾中所有文件的方法
- C#如何遍歷Dictionary
- C#集合遍歷時(shí)刪除和增加元素的方法
相關(guān)文章
ASP.NET:把a(bǔ)shx寫到類庫里并在頁面上調(diào)用的具體方法
最近在調(diào)整博客的架構(gòu),進(jìn)一步把表現(xiàn)和業(yè)務(wù)分離,所以要把之前用ashx搞的那些Http Handler放到類庫中,下面是具體的步驟及代碼2013-06-06解決ASP.NET Core Mvc文件上傳限制問題實(shí)例
本篇文章主要介紹了解決ASP.NET Core Mvc文件上傳限制問題,具有一定的參考價(jià)值,有需要的可以了解一下。2016-11-11asp.net uploadify實(shí)現(xiàn)多附件上傳功能
這篇文章主要為大家詳細(xì)介紹了asp.net uploadify實(shí)現(xiàn)多附件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11C#利用服務(wù)器實(shí)現(xiàn)客戶端之間通信
這篇文章主要為大家詳細(xì)介紹了C#利用服務(wù)器實(shí)現(xiàn)客戶端之間通信,感興趣的小伙伴們可以參考一下2016-08-08asp.net運(yùn)算符之邏輯運(yùn)算符以及其他運(yùn)算符介紹與實(shí)例
在.net中運(yùn)算符分類很多種類型,包括有我們常用的boolean型運(yùn)算符,通用的運(yùn)行符有 ==、!=、<、>、<=、>=、binary +、binary -、^、&、|、~、++、-- 和 sizeof()2013-08-08asp.net小孔子cms中的數(shù)據(jù)添加修改
最近都在看小孔子cms的代碼,其添加與修改數(shù)據(jù)十分方便,做下筆記,代碼主要提取自小孔子cms,去掉了不用的函數(shù)并把相關(guān)代碼寫到一個(gè)文件中2008-08-08