C#中遍曆各類資料集合的方法總結

來源:互聯網
上載者:User

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來迴圈遍曆,只不過一個是先進先出另一個是先進後出罷了。
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的名稱和值全部擷取出來了。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.