流畅的python学习(二)自用

列表推导

symbols = '$*#@3'
codes = [ord(symbol) for symbol in symbols]
print(codes)

ord()函数返回字符的ASCLL值
列表推导常用于创建代码简短的新列表,用列表推导来重复获取一个函数有副作用,(等我查查是什么再写)
列表推导把一个列表再加工成新列表

生成器表达式

symbols = '$*#@3'
codes = (ord(symbol) for symbol in symbols)
print(codes)

这两种语法的不同就是一个是[ ],另一个是( )

q = (s ** 2 for s in range(10))
p = [s ** 2 for s in range(10)]
print(type(q))
print(type(p))
>>><class 'generator'>
>>><class 'list'>

从这里也可以看出列表推导得到的是list列表,而生成器表达式得到一个生成器

列表推导一个潜在缺陷就是如果输入非常大的时候会产生一个非常大的结果集,占用大量内存。如果你对内存比较敏感,那么你可以使用生成器表达式迭代产生过滤的元素。
(这段话抄的 https://www.jianshu.com/p/d6a7adb92869)

按我自己的理解,列表推导是先建好一个完整的列表,再一个个的根据条件去修改列表里的值。生成器表达式是算好一个值再把它添到列表里去。而且列表推导是你把推导的代码写下来它就会执行,就开始占用内存,生成器是等你用到了,访问它的时候它才会执行,单把这个代码式写下来是不会执行的。(参考 https://www.cnblogs.com/pythoncainiao/p/10105233.html)

filter函数
filter() 函数用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表。该接收两个参数,第一个为函数,第二个为序列,序列的每个元素作为参数传递给函数进行判,然后返回 True 或 False,最后将返回 True 的元素放到新列表中。
(注意: Pyhton2.7 返回列表,Python3.x 返回迭代器对象)

def is_odd(n):
    return n % 2 == 1
 
newlist = filter(is_odd, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
print(newlist)

map函数
map() 会根据提供的函数对指定序列做映射。
第一个参数 function 以参数序列中的每一个元素调用 function 函数,返回包含每次 function 函数返回值的新列表。

def square(x) :            # 计算平方数	
	return x ** 2

map(square, [1,2,3,4,5])   # 计算列表各个元素的平方

map(lambda x: x ** 2, [1, 2, 3, 4, 5])  # 使用 lambda 匿名函数
[1, 4, 9, 16, 25]
 
# 提供了两个列表,对相同位置的列表数据进行相加
map(lambda x, y: x + y, [1, 3, 5, 7, 9], [2, 4, 6, 8, 10])
[3, 7, 11, 15, 19]

菜鸟教程抄的

抄的太多,不敢贴原创了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值