我第一次使用词典。我想知道如何计算每个字典中有多少键值对,其值为“可用”。我知道我可能会使用len()
。
seats = {
'A': {'A1':'available', 'A2':'unavailable', 'A3':'available'},
'B': {'B1':'unavailable', 'B2':'available', 'B3':'available'},
'C': {'C1':'available', 'C2':'available', 'C3':'unavailable'},
'D': {'D1':'unavailable', 'D2':'available', 'D3':'available'} }
rowChoice = raw_input('What row? >> ')
numSeats = input('How many Seats? >> ')
我对此非常陌生,所以我真的需要一个非常简单的方法,可能需要一些注释或解释它是如何工作的。
答案 0 :(得分:3)
我将使用以下语句来计算每个嵌套字典的值:
{k: sum(1 for val in v.itervalues() if val == 'available') for k, v in seats.iteritems()}
这将使用与seats
相同的键构建新词典,每个值都是可用席位数。具有生成器技巧的sum(..)
有效地计算所包含的每行字典的所有值,其中值等于'available'
。
结果:
{'A': 2, 'C': 2, 'B': 2, 'D': 2}
要显示您过滤的特定行的可用座位,只需使用len()
:
row_available = [k for k, v in seats[rowChoice].iteritems() if v == 'available']
avail_count = len(row_available)
if avail_count:
print 'there {is_are} {count} seat{plural} available in row {rowChoice}, seat{plural} {seats}'.format(
is_are='are' if avail_count > 1 else 'is', count=avail_count,
plural='s' if avail_count > 1 else '', rowChoice=rowChoice,
seats=row_available[0] if avail_count == 1 else ' and '.join([', '.join(row_available[:-1]), row_available[-1]]))
对于rowChoice = 'A'
,这会打印:
there are 2 seats available in row A, seats A1 and A3
但它会调整以形成更多或更少座位的连贯句子。
答案 1 :(得分:3)
使用collections.Counter
和itertools.chain
:
from collections import Counter
from itertools import chain
print Counter(chain.from_iterable(i.itervalues() for i in seats.itervalues()))
# Counter({'available': 8, 'unavailable': 4})