C#中遍歷各類數(shù)據(jù)集合的方法總結(jié)_.Net教程
推薦:Google免費(fèi)的SVN服務(wù)器管理VS2010代碼前言 Google免費(fèi)為我們提供了代碼管理的SVN服務(wù)器。首先我這里用的Win7 64的電腦系統(tǒng),用VS2010進(jìn)行的代碼開(kāi)發(fā)。這里管理代碼需要以下準(zhǔn)備(現(xiàn)在用的都是最新的版本): 1.(SVN)TortoiseSVN-1.7.12.24070-x64-svn-1.7.9 下載地址鏈接http://url.cn/FTvkSk當(dāng)然也可以在官
C#中遍歷各類數(shù)據(jù)集合的方法,這里自己做下總結(jié):1.枚舉類型
復(fù)制代碼 代碼如下:www.wf0088.com
//遍歷枚舉類型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ù)制代碼 代碼如下:www.wf0088.com
//遍歷元素為string類型的隊(duì)列
foreach (string text in arraylist)
{
ary.Add(text);
}
此外遍歷Queue隊(duì)列和Stack堆棧的方式與ArrayList基本相同, 都可以使用foreach來(lái)循環(huán)遍歷,只不過(guò)一個(gè)是先進(jìn)先出另一個(gè)是先進(jìn)后出罷了。
3.Winform窗體中的控件
復(fù)制代碼 代碼如下:www.wf0088.com
//遍歷尋找主窗體中的控件,并將符合條件的控件從窗體上去除
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ù)制代碼 代碼如下:www.wf0088.com
//遍歷完整哈希表中的鍵和值
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ù)制代碼 代碼如下:www.wf0088.com
//遍歷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ù)制代碼 代碼如下:www.wf0088.com
//遍歷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ù)制代碼 代碼如下:www.wf0088.com
//遍歷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的名稱和值全部獲取出來(lái)了。
分享:asp.net利用Ajax和Jquery在前臺(tái)向后臺(tái)傳參數(shù)并返回值的實(shí)例asp.net利用Ajax和Jquery在前臺(tái)向后臺(tái)傳參數(shù)并返回值的實(shí)例,需要的朋友可以參考一下
相關(guān).Net教程:
- asp.net如何得到GRIDVIEW中某行某列值的方法
- .net SMTP發(fā)送Email實(shí)例(可帶附件)
- js實(shí)現(xiàn)廣告漂浮效果的小例子
- asp.net Repeater 數(shù)據(jù)綁定的具體實(shí)現(xiàn)
- Asp.Net 無(wú)刷新文件上傳并顯示進(jìn)度條的實(shí)現(xiàn)方法及思路
- Asp.net獲取客戶端IP常見(jiàn)代碼存在的偽造IP問(wèn)題探討
- VS2010 水晶報(bào)表的使用方法
- ASP.NET中操作SQL數(shù)據(jù)庫(kù)(連接字符串的配置及獲取)
- asp.net頁(yè)面?zhèn)髦禍y(cè)試實(shí)例代碼
- DataGridView - DataGridViewCheckBoxCell的使用介紹
- asp.net中javascript的引用(直接引入和間接引入)
- 三層+存儲(chǔ)過(guò)程實(shí)現(xiàn)分頁(yè)示例代碼
.Net教程Rss訂閱編程教程搜索
.Net教程推薦
- 淺析asp.net 里 include UTF8 垃圾問(wèn)題
- 解析ASP.NET頁(yè)面數(shù)據(jù)導(dǎo)出到Excel或Word
- 關(guān)于ASP.NET在IIS一些問(wèn)題的經(jīng)驗(yàn)總結(jié)
- 解讀非托管COM組件的使用
- 解析Asp.Net頁(yè)面執(zhí)行流程
- 詳解.NET中的代碼動(dòng)態(tài)編譯
- asp.net使用存儲(chǔ)過(guò)程實(shí)現(xiàn)用戶登錄
- 無(wú)刷新仿google波形扭曲彩色Asp.net驗(yàn)證碼
- .Net業(yè)務(wù)平臺(tái)的數(shù)值精度陷阱與解決方法
- ASP.NET技巧:DataGrid傳統(tǒng)分頁(yè)方式
- 相關(guān)鏈接:
- 教程說(shuō)明:
.Net教程-C#中遍歷各類數(shù)據(jù)集合的方法總結(jié)。