C#中遍歷各類數據集合的方法總結


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來循環遍歷,只不過一個是先進先出另一個是先進后出罷了。 

ArrayList list = new ArrayList();
//for遍歷
for (int i = 0; i < list.Count; i++)
{
  SE se = (SE)list[i];
  Console.WriteLine(se.Name);
}
//foreach遍歷
foreach (Object obj in list)
{
  SE se = (SE)list[i];
  Console.WriteLine(se.Name);
}

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的名稱和值全部獲取出來了。

8.List<T>

//for遍歷
for (int i = 0; i < list.Count; i++)
{
  //遍歷時不需要類型轉換
  Console.WriteLine(list[i]);
}
//foreach遍歷
foreach (SE obj in list)
{
  //遍歷時不需要類型轉換
  Console.WriteLine(obj);
}

9.Dictionary<K,V>

//遍歷Values
foreach (SE se in list.Values)
{
  //遍歷時不需要類型轉換
  Console.WriteLine(se);
}
 
//同時遍歷
foreach (KeyValuePair<string, SE> en in list)
{
  Console.WriteLine(en.Key);
  Console.WriteLine(en.Value.Name);
}
//KeyValuePair<TKey,TValue>是一個泛型結構

 

 

 

轉: https://www.cnblogs.com/H2921306656/p/6675327.html

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM