我有一个表单中的字段列表。
fields = [{'name':'count', 'label':'Count'},{'name':'type', 'label':'Type'}]
我想提取仅包含名称的内容并将其放入列表中。目前,我的做法是:
names = []
for field in fields:
names.append(field['name'])
有没有另外一种方法来完成相同的事情,而不涉及遍历列表。
我正在使用Python 2.7。
感谢您的帮助!
我有一个表单中的字段列表。
fields = [{'name':'count', 'label':'Count'},{'name':'type', 'label':'Type'}]
我想提取仅包含名称的内容并将其放入列表中。目前,我的做法是:
names = []
for field in fields:
names.append(field['name'])
有没有另外一种方法来完成相同的事情,而不涉及遍历列表。
我正在使用Python 2.7。
感谢您的帮助!
>>> fields = [{'name':'count', 'label':'Count'},{'name':'type', 'label':'Type'}]
>>> [f['name'] for f in fields]
['count', 'type']
names = [x['name'] for x in fields]
例子:
>>> fields = [{'name':'count', 'label':'Count'},{'name':'type', 'label':'Type'}]
>>> [x['name'] for x in fields]
['count', 'type']
如果names
已经存在,您可以使用map函数(以相同的方式创建)将新列表中的每个成员附加到它上面:
map(names.append, [x['name'] for x in fields])
例子:
>>> a = [1, 2 ,3]
>>> map(a.append, [2 ,3, 4])
[None, None, None]
>>> a
[1, 2, 3, 2, 3, 4]
编辑:
不确定为什么我没有提到list.extend
,这里有一个例子:
names.extend([x['name'] for x in fields])
names += [x['name'] for x in fields]
您也可以使用像预期的那样使用if
语句即可实现“即时”筛选:
names = [x['name'] for x in fields if x and x['name'][0] == 'a']
例子:
>>> l1 = ({'a':None}, None, {'a': 'aasd'})
>>> [x['a'] for x in l1 if (x and x['a'] and x['a'][0] == 'a')]
['aasd']
这将生成一个名字以'a'开头的所有x的列表。
names = [x ['name'] for x in fields]
可以实现。
如果列表 names
已经存在,则:
names += [x['name'] for x in fields]
map(names.append, [x['name'] for x in fields])
非常不符合惯用法。在OP使用的Python 2中,它会创建然后丢弃一个空列表,在Python 3中则根本不执行任何操作。 - DSM如果表单已经定义良好,也就是说,每个字典中都必须定义'name',那么您可以使用以下代码:
map(lambda x: x['name'], fields)
map(lambda x: x['name'], filter(lambda x: x.has_key('name'), fields))
names = []
这一行了吗?那是我们所给的内容的一部分。 - DSMnames += [f['name'] for f in fields]
。 - Hyperboreusnames = [f['name'] for f in fields]
这一行代码与 OP 的三行代码具有相同的功能。 - Hyperboreus