如何从字典中获取键和值
本文关键字:获取 键和值 字典 | 更新日期: 2023-09-27 18:28:43
所以我有一个字典,设置如下:
Dictionary<DateTime, List<Double>>
日期和时间是我从excel电子表格中提取的月份,然后我的整数是美元金额。列如下所示:
7/1/10 | 6/1/10
----------------
100.00 | 90.00
----------------
3.00 | 20.00
----------------
35.00 | 10.00
依此类推,持续约6个月。我需要得到这些密钥和值。我需要把它放进我的数据库。例如,对于值100.00、3.00、35.00,它们都与10年7月1日的月份相协调(第一个键下面有3个值等)
有人能告诉我如何迭代这些东西吗?当我调试我的字典时,所有的信息都输入正确,但我无法将它们提取出来。
只需在嵌套循环中直接迭代它们
Dictionary<DateTime, List<Double>> map;
foreach (var pair in map) {
DateTime dt = pair.Key;
foreach (double value in pair.Value) {
// Now you have the DateTime and Double values
}
}
foreach(KeyValuePair<DateTime,List<Double> pair in dictionaryName){
DateTime dt = pair.Key;
List<Double> doubleList = pair.Value;
//With this method you now can step through each key value pair
}
或带有linq:
var myDict = new Dictionary<DateTime, List<Double>>();
var julyValues= myDict.Where(r => r.Key == new DateTime(2010, 7, 1))
.Select(r => r.Value);
或按分组:
var groupValues= myDict.GroupBy(r => r.Key)
.Select(grp =>
new { grp.Key,
values = grp.Select(r => r.Value)
}
);
您可以对奇异值(如果您知道密钥)执行此操作
List<double> values = myDictionary[someDateValue];
您可以使用foreach
来迭代所有密钥对
foreach(var pair in myDictionary)
{
DateTime keyValue = pair.Key;
List<double> valueValue = pair.Value;
}