在我的一项任务中,我被要求这样做:
1 >>> d = {1: 'one', 2: 'two', 3: 'three', 4: 'four', 5: 5}
2 >>> print ________
3 ['one', 'two', 'three', 'four']
如何仅使用上述代码的第2行中的一行代码而不导入任何其他函数来获取第3行中的输出['one', 'two', 'three', 'four']
?
我只能打印出字典的所有值,而不能使用print(list(d.values()))
排除最后一个元素,而我的结果是['one', 'two', 'three', 'four', 5]
答案 0 :(得分:2)
如果只想打印字符串字典值(在给定的示例中将不包括最后一个整数值),则可以在print()中使用列表理解,并检查字典值是否为字符串类型:>
print([val for val in d.values() if type(val) == str])
如果您有这样的字典,这也将起作用:
d = {1: 'one', 2: 'two', 3: 'three', 4: 'four', 5: 5, 6: 'six'}
print([val for val in d.values() if type(val) == str])
['one', 'two', 'three', 'four', 'six']
答案 1 :(得分:0)
一个答案:
list(d.values())[:-1]
答案 2 :(得分:0)
d.values()不可下标,因此您需要将其转换为列表。 然后,您可以获得整个列表减去最后一个元素
print (list(d.values())[:-1])
答案 3 :(得分:0)
print([v for (k,v) in d.items() if type(v) != int])
输出:
['one', 'two', 'three', 'four']