Python 推导式
Python推导式(comprehensions,又称解析式)是Python的一种独有特性,它可以从一个数据序列构建另一个新的数据序列。这种特性相当于语法糖的存在,可以简化代码。Python推导式包括列表推导式、字典推导式、集合推导式和元组推导式。
列表推导式是利用其他列表创建新列表的一种方式,它的工作原理类似于for循环,可以对得到的元素进行转换或筛选。它的基本语法格式是:[表达式 for 变量 in 序列],其中表达式是列表生成元素表达式,可以是有返回值的函数;变量是迭代列表的元素;序列是要迭代的列表。此外,还可以在列表推导式中加入if条件,以过滤列表中不符合条件的值,其语法格式为:[表达式 for 变量 in 序列 if 条件]。
字典推导式则是利用其他字典创建新字典的一种方式,其基本语法格式为:{变量(key):值 for 变量 in 序列 if 条件},其中变量是字典的键,值是对键进行某种操作后的结果,序列是要迭代的列表,if条件可以过滤列表中不符合条件的键值对。
集合推导式类似于列表推导式,但它生成的是集合而不是列表。其语法格式与列表推导式类似,只是将方括号[]替换为大括号{}。
元组推导式与列表推导式类似,但生成的是元组而不是列表。其语法格式与列表推导式类似,只是将方括号[]替换为小括号()。
Python 支持各种数据结构的推导式:
- 列表(list)推导式
- 字典(dict)推导式
- 集合(set)推导式
- 元组(tuple)推导式
列表推导式
列表推导式格式为:
python
[表达式 for 变量 in 列表]
[out_exp_res for out_exp in input_list]
或者
python
[表达式 for 变量 in 列表 if 条件]
[out_exp_res for out_exp in input_list if condition]
- out_exp_res:列表生成元素表达式,可以是有返回值的函数。
- for out_exp in input_list:迭代 input_list 将 out_exp 传入到 out_exp_res 表达式中。
- if condition:条件语句,可以过滤列表中不符合条件的值。
如下示例,使用推导式过滤掉长度小于或等于3的字符串列表,并将剩下的转换成大写字母:
示例代码如下
python
ikun = ['ikun','is','a','good','him']
ikuns = [kun.upper()for kun in ikun if len(kun)>3]
print(ikuns)
输出结果如下
字典推导式
字典推导基本格式:
python
{ key_expr: value_expr for value in collection }
或
{ key_expr: value_expr for value in collection if condition }
使用字符串及其长度创建字典:
示例代码如下
python
ikunList = ['ikun','is', 'a','good','him']
# 将列表中各字符串值为键,各字符串的长度为值,组成键值对
newdict = {key:len(key) for key in ikunList}
print(newdict)
输出结果如下
集合推导式
集合推导式基本格式:
python
{ expression for item in Sequence }
或
{ expression for item in Sequence if conditional }
计算数字 1,2,3 的平方数:
示例代码如下
python
setnew = {i**2 for i in (1,2,3)}
print(setnew)
输出结果如下
元组推导式(生成器表达式)
元组推导式可以利用 range 区间、元组、列表、字典和集合等数据类型,快速生成一个满足指定需求的元组。
元组推导式基本格式:
python
(expression for item in Sequence )
或
(expression for item in Sequence if conditional )
元组推导式和列表推导式的用法也完全相同,只是元组推导式是用 () 圆括号将各部分括起来,而列表推导式用的是中括号 [],另外元组推导式返回的结果是一个生成器对象。
如下示例代码我们可以使用下面的代码生成一个包含数字 1~9 的元组:
示例代码如下
python
a = (x for x in range(1,10))
print(a)
print(tuple(a))
b=(x for x in range(1,10) if x%2==0)
print(b)
print(tuple(b))
输出结果如下