C#探秘系列(一)——ToDictionary,ToLookup
這個(gè)系列我們看看C#中有哪些我們知道,但是又不知道怎么用,又或者懶得去了解的東西,比如這篇我們要介紹的toDictionary和ToLookup。

從圖中我們看到有四個(gè)ToXXX的方法,其中ToArray和ToList,我想大家用的是非常非常多,但是ToDictionary和ToLookup不見(jiàn)得有多少人用了,但不能否認(rèn)的是這些方法確實(shí)很有用。
不多廢話了,直接如主題,我們有這樣的一個(gè)實(shí)體,包含:票號(hào),訂單號(hào),備注。
class Ticket
{
/// <summary>
/// 票號(hào)
/// </summary>
public string TicketNo { get; set; }
/// <summary>
/// 訂單號(hào)
/// </summary>
public int OrderID { get; set; }
/// <summary>
/// 備注
/// </summary>
public string Description { get; set; }
}
好了,我們看看需求,票號(hào)和訂單號(hào)是一對(duì)多的關(guān)系,也就是說(shuō)一個(gè)訂單號(hào)可能包含幾個(gè)票號(hào),每個(gè)票號(hào)都有自己對(duì)應(yīng)的狀態(tài),比如票號(hào)有 “改簽”,"未使用",“成交”,"退票" 等等,下面我們灌一批數(shù)據(jù)進(jìn)去。
public static List<Ticket> GetList()
{
return new List<Ticket>()
{
new Ticket(){ TicketNo="999-12311",OrderID=79121281,Description="改簽"},
new Ticket(){ TicketNo="999-24572",OrderID=29321289,Description="退票"},
new Ticket(){ TicketNo="999-68904",OrderID=19321289,Description="成交"},
new Ticket(){ TicketNo="999-24172",OrderID=64321212,Description="未使用"},
new Ticket(){ TicketNo="999-24579",OrderID=19321289,Description="退票"},
new Ticket(){ TicketNo="999-21522",OrderID=79121281,Description="未使用"},
new Ticket(){ TicketNo="999-24902",OrderID=79121281,Description="退票"},
new Ticket(){ TicketNo="999-04571",OrderID=29321289,Description="改簽"},
new Ticket(){ TicketNo="999-23572",OrderID=96576289,Description="改簽"},
new Ticket(){ TicketNo="999-24971",OrderID=99321289,Description="成交"}
};
}
舉個(gè)例子: 我需要統(tǒng)計(jì)各個(gè)訂單號(hào)中的票號(hào)情況。
很明顯,這是一個(gè)分組排序的問(wèn)題,可能你馬上就想起了groupby來(lái)實(shí)現(xiàn),當(dāng)然groupby是可以實(shí)現(xiàn)的,不過(guò)groupby不能算是一種數(shù)據(jù)
結(jié)構(gòu),不能帶有索引,沒(méi)有字典那樣容易輸出和操作。
方案一: 采用普通的foreach循環(huán)。
一般情況下,可能有一部分人都采用這種原始的方法,將list數(shù)據(jù)通過(guò)foreach循環(huán)放到dictionary中,就是代碼寫(xiě)的多一些,也算
是最靈活的。
Dictionary<int, Ticket> dic = new Dictionary<int, Ticket>();
foreach (var item in ticketlist)
{
if (!dic.ContainsKey(item.OrderID))
{
dic.Add(item.OrderID, item);
}
else
{
dic[item.OrderID] = item;
}
}
方案二:使用ToDictionary

從圖中我們可以看到,發(fā)生悲劇的異常了,我們知道dictionary中key是不能重復(fù)的,然而ToDictionary中并沒(méi)有給我們做key的重復(fù)值判斷,那也就側(cè)面說(shuō)明ToDictionary在kv中只能是 “一對(duì)一”的關(guān)系,也就是v中永遠(yuǎn)只會(huì)有一條記錄,顯然這不是我需要的,在了解ToDictionary原理后,該方案失敗。
方案三: 使用ToLookup
也許微軟知道客戶有這么個(gè)需求,就采用了一個(gè)ToDictionary的加強(qiáng)版,你也可以認(rèn)為是一種新的字典數(shù)據(jù)結(jié)構(gòu),它就避免了這種“一對(duì)一”的關(guān)系,采用“一對(duì)多”的實(shí)現(xiàn)。
var dic = ticketlist.ToLookup(i => i.OrderID);
foreach (var item in dic)
{
Console.WriteLine("訂單號(hào):" + item.Key);
foreach (var item1 in item)
{
Console.WriteLine("\t\t" + item1.TicketNo + " " + item1.Description);
}
}

而且ToLookup和字典一樣,是帶有索引形式,這個(gè)groupby就不具備了,當(dāng)然Tolookup還有一個(gè)強(qiáng)大的功能,就是使用Func<TSource, TElement> elementSelector來(lái)對(duì)現(xiàn)在的v元素進(jìn)行轉(zhuǎn)換來(lái)避免我剛才 Console.WriteLine("\t\t" + item1.TicketNo + " " + item1.Description);語(yǔ)句
![]() |
好了,大概就這樣了,趕緊停筆,不說(shuō)了。。。妹子催著要去公園。o(∩_∩)o
- Lua Table轉(zhuǎn)C# Dictionary的方法示例
- C#中數(shù)組、ArrayList、List、Dictionary的用法與區(qū)別淺析(存取數(shù)據(jù))
- C#數(shù)組中List, Dictionary的相互轉(zhuǎn)換問(wèn)題
- C#常見(jiàn)的幾種集合 ArrayList,Hashtable,List<T>,Dictionary<K,V> 遍歷方法對(duì)比
- C#中Dictionary泛型集合7種常見(jiàn)的用法
- C#中查找Dictionary中的重復(fù)值的方法
- C#實(shí)現(xiàn)自定義Dictionary類(lèi)實(shí)例
- C#中Dictionary類(lèi)使用實(shí)例
- C#針對(duì)xml文件轉(zhuǎn)化Dictionary的方法
- C#泛型集合Dictionary<K,V>的使用方法
- C#中Dictionary的作用及用法講解
- C#泛型Dictionary的用法實(shí)例詳解
- C#中查找Dictionary中重復(fù)值的方法
- C# Hashtable/Dictionary寫(xiě)入和讀取對(duì)比詳解
- C# Dictionary和SortedDictionary的簡(jiǎn)介
相關(guān)文章
C#遞歸實(shí)現(xiàn)將一整數(shù)逆序后放入一數(shù)組中
這篇文章主要介紹了C#遞歸實(shí)現(xiàn)將一整數(shù)逆序后放入一數(shù)組中,是遞歸算法的一個(gè)簡(jiǎn)單應(yīng)用,需要的朋友可以參考下2014-10-10
C#簡(jiǎn)易圖片格式轉(zhuǎn)換器實(shí)現(xiàn)方法
這篇文章主要介紹了C#簡(jiǎn)易圖片格式轉(zhuǎn)換器實(shí)現(xiàn)方法,涉及C#基于WinForm操作圖片的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11
C# WinForm制作登錄界面的實(shí)現(xiàn)步驟
本文主要介紹了C# WinForm制作登錄界面的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05
C#根據(jù)前臺(tái)傳入實(shí)體名稱實(shí)現(xiàn)動(dòng)態(tài)查詢數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了C#如何根據(jù)前臺(tái)傳入實(shí)體名稱實(shí)現(xiàn)動(dòng)態(tài)查詢數(shù)據(jù)的功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-04-04


