3 回答

TA貢獻1828條經驗 獲得超3個贊
根據您的描述,您似乎有一個包含某個鍵TKey和一個值的字典object。
var sampleDictionary = new Dictionary<TKey, object>();
... populate dictionary ...
我們并不真正關心密鑰。如果您的object實例類型可轉換為doubles,那么您可以做一些不同的事情:
// Perform a LINQ operation on the `Values` collection of the dictionary:
var sum = sampleDictionary.Values.Select(v => Convert.ToDouble(v)).Sum();
或者
// Perform a LINQ operation directly on the dictionary
// Use this is if you might potentially need to incorporate TKey into your result
var sum = sampleDictionary.Select(d => Convert.ToDouble(d.Value)).Sum();
.Sum()如果愿意,您還可以將 lambda 移入函數中,以縮短它:
var sum = sampleDictionary.Values.Sum(v => Convert.ToDouble(v));
或者
var sum = sampleDictionary.Sum(d => Convert.ToDouble(d.Value));
這里沒有一種方法真的比另一種更好,只需選擇一種現在可以工作并且在您的應用程序上下文中有意義的方法。
如果您objects可能無法轉換為double,請在評論中告訴我們,因為這必須進行一些重構。

TA貢獻1772條經驗 獲得超8個贊
看起來我的問題的答案是在我的字典上簡單地使用 LINQ .sum。我收到了兩個這樣的答案,但我只能接受其中一個。
為了為我試圖做的事情提供更多背景......
beestatData.Data.Where(datum =>
isWithinDateRange(new DateTime((int)datum.Year, (int)datum.Month, (int)datum.Day), startDate, endDate))
.Sum(datum => datum.AuxiliaryHeat1/60/60);
我不僅第一次使用 C#,而且還嘗試使用 JSON 從我的 Ecobee 恒溫器中獲取數據。為了以各種方式定制數據,我最終得到了一堆不同的函數,它們可以抓取數據并在循環中對其進行操作。我認為這會變得一團糟,并認為使用函數式編程是可行的方法。
我發現 .Where 大致相當于 Java 中的 .filter,但我懷疑 .Sum 是否與 .mapToDouble.Sum() 相同。我很高興看到答案很簡單,現在我可以輕松地在特定日期內獲取系統的總運行時間。
注意:這還沒有編譯和工作,但我相信這是由于我的代碼中的其他內容。
添加回答
舉報