本章接着上篇文章讲
一.推导式
列表推导式是Python基础,好用,而又非常重要的功能,也是最受欢迎的Python特性之一。本质上可以把列表推导式理解成一种集合了变换和筛选功能的函数,通过这个函数把一个列表转换成另一个列表的过程
- 普通推导式
# 简单列表推导式
list1 = [i for i in range(5)]
print(list1)
# 生成偶数(1-10之间)
list2 = [i for i in range(1, 11) if i%2 == 0]
print(list2)
# 生成平方数(1-10之间)
list3 = [pow(i, 2) for i in range(1, 11)]
print(list3)
'''
[0,1,2,3,4]
[2,4,6,8,10]
[1,4,9,16,25,36,49,56,64,81,100]
'''
- 二维推导式
# 2-19所有的合数 ,这里使用了集合的去重
list4 = {j for i in range(2, 20) for j in range(i*i, 20, i)}
ptint(list4)
# 2-19所有的质数
list5 = [i for i in range(2, 20) if i not in list4]
print(list5)
'''
{4, 6, 8, 9, 10, 12, 14, 15, 16, 18}
[2, 3, 5, 7, 11, 13, 17, 19]
'''
Python中还有字典推导式、元组推导式、集合推导式等,与列表推导式使用方式大致相同
二.enumerate 和 format 函数
- enumerate函数
基本介绍:enumerate() 函数用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中 enumerate(sequence, start=0)
for i, values in enumerate(['a', 's', 'd']):
print(i + ':' +values)
'''
0:a
1:s
2:d
'''
- format函数
基本介绍:一种格式化字符串的函数 ,它增强了字符串格式化的功能。
基本语法是通过 {} 和 : 来代替以前的 % 。
format 函数可以接受不限个参数,位置可以不按顺序
基本操作
format骚操作
三.微妙的字符串
-
这些行为是由于 Cpython 在编译优化时, 某些情况下会尝试使用已经存在的不可变对象而不是每次都创建一个新对象. (这种行为被称作字符串的驻留[string interning])
-
发生驻留之后, 许多变量可能指向内存中的相同字符串对象. (从而节省内存)
-
在上面的代码中, 字符串是隐式驻留的. 何时发生隐式驻留则取决于具体的实现. 这里有一些方法可以用来猜测字符串是否会被驻留:
-
所有长度为 0 和长度为 1 的字符串都被驻留.
-
字符串在编译时被实现 (‘asd’ 将被驻留, 但是 ‘’.join([‘a’, ‘s’, ‘d’] 将不会被驻留)
-
字符串中只包含字母,数字或下划线时将会驻留. 所以 ‘asd!’ 由于包含 ! 而未被驻留. 可以在这里找到 CPython 对此规则的实现.
四.从有到无
为啥会这样,是不是很奇怪,list_testt明明已经append了然后赋值给自己了为啥还是None呢
- 大多数修改序列/映射对象的方法, 比如 list.append, dict.update, list.sort 等等. 都是原地修改对象并返回 None. 这样做的理由是, 如果操作可以原地完成, 就可以避免创建对象的副本来提高性能
五.一蹴即至
是不是觉得很奇怪呢?
因为他们使用的是相同的地址