考虑像一个字典
mydict = {
'Apple': {'American':'16', 'Mexican':10, 'Chinese':5},
'Grapes':{'Arabian':'25','Indian':'20'} }
如何访问该字典的特定元素?例如,我想在格式化Apple的第一个元素之后打印第一个元素,在我们的例子中只是'American'吗?
附加信息上述数据结构是通过解析python函数中的输入文件创建的。一旦创建,它对于该运行保持不变。
我在我的函数中使用这个数据结构。
因此,如果文件发生更改,则下次运行此应用程序时,文件的内容会有所不同,因此此数据结构的内容将不同,但格式将相同。所以你看我在我的功能中我不知道Apple中的第一个元素是'美国'或其他任何东西所以我不能直接使用'美国'作为关键。
鉴于它是一本字典,您可以使用键来访问它。将字典存储在“Apple”下,执行以下操作:
>>> mydict["Apple"]
{'American': '16', 'Mexican': 10, 'Chinese': 5}
得到其中有多少是美国人(16),这样做:
>>> mydict["Apple"]["American"]
'16'
如果问题是,如果我知道我有一个包含'苹果'作为水果和'美国'作为一种苹果的词典,我会使用:
myDict = {'Apple': {'American':'16', 'Mexican':10, 'Chinese':5},
'Grapes':{'Arabian':'25','Indian':'20'} }
print myDict['Apple']['American']
正如其他人所说。如果问题是,你不知道当你在dict数据结构的dict中读取任意文件时,'Apple'作为水果和'美国'作为'Apple'类型存在,你可以做类似的事情:
print [ftype['American'] for f,ftype in myDict.iteritems() if f == 'Apple' and 'American' in ftype]
或者更好,如果你知道只有苹果公司拥有美国人的类型,那么你就不必不必要地迭代整个决定词:
if 'Apple' in myDict:
if 'American' in myDict['Apple']:
print myDict['Apple']['American']
在所有这些情况下,字典实际存储条目的顺序无关紧要。如果您真的关心订单,那么您可以考虑使用OrderedDict
:
http://docs.python.org/dev/library/collections.html#collections.OrderedDict
当我注意到你的描述时,你只知道你的解析器会给你一个字典,其值是字典,就像这样:
sampleDict = {
"key1": {"key10": "value10", "key11": "value11"},
"key2": {"key20": "value20", "key21": "value21"}
}
所以你必须迭代你的父词典。如果您想打印或访问sampleDict.values()
列表中的所有第一个字典键,您可以使用以下内容:
for key, value in sampleDict.items():
print value.keys()[0]
如果您只想访问sampleDict.values()
中第一个项目的第一个键,这可能很有用:
print sampleDict.values()[0].keys()[0]
如果您使用问题中给出的示例,我的意思是:
sampleDict = {
'Apple': {'American':'16', 'Mexican':10, 'Chinese':5},
'Grapes':{'Arabian':'25','Indian':'20'}
}
第一个代码的输出是:
American
Indian
第二个代码的输出是:
American
作为奖励,我想为您的问题提供一种不同的解决方案。您似乎正在处理嵌套字典,这通常是单调乏味的,尤其是当您必须检查是否存在内部键时。
在pypi上有一些有趣的图书馆,这里有一个quick search。
在您的具体情况下,dict_digger似乎适合。
>>> import dict_digger
>>> d = {
'Apple': {'American':'16', 'Mexican':10, 'Chinese':5},
'Grapes':{'Arabian':'25','Indian':'20'}
}
>>> print(dict_digger.dig(d, 'Apple','American'))
16
>>> print(dict_digger.dig(d, 'Grapes','American'))
None
您可以使用dict['Apple'].keys()[0]
获取Apple
字典中的第一个键,但不能保证它将是American
。字典中键的顺序可以根据字典的内容和键的添加顺序而改变。
你不能依赖词典上的顺序。但你可以试试这个:
dict['Apple'].items()[0][0]
如果您想要保留订单,您可能想要使用:http://www.python.org/dev/peps/pep-0372/#ordered-dict-api
我知道这已经8岁了,但似乎没有人真正阅读并回答过这个问题。
您可以在dict上调用.values()来获取内部dicts的列表,从而通过索引访问它们。
>>> mydict = {
... 'Apple': {'American':'16', 'Mexican':10, 'Chinese':5},
... 'Grapes':{'Arabian':'25','Indian':'20'} }
>>>mylist = mydict.values()
>>>mylist[0]
{'American':'16', 'Mexican':10, 'Chinese':5},
>>>mylist[1]
{'Arabian':'25','Indian':'20'}
>>>myInnerList1 = mylist[0].values()
>>>myInnerList1
['16', 10, 5]
>>>myInnerList2 = mylist[1].values()
>>>myInnerList2
['25', '20']
简单示例了解如何访问字典中的元素: -
d = {'dog' : 'bark', 'cat' : 'meow' }
print(d.get('cat'))
print(d.get('lion'))
print(d.get('lion', 'Not in the dictionary'))
print(d.get('lion', 'NA'))
print(d.get('dog', 'NA'))
探索有关Python Dictionaries and learn interactively here...的更多信息