目录
字典居然是可以排序的?
在Python 3.6之前字典不可排序的思想,似乎已经根深蒂固。
# Python2.7.10
>>> mydict = {str(i):i for i in range(5)}
>>> mydict
{'1': 1, '0': 0, '3': 3, '2': 2, '4': 4}
假如哪一天,有人跟你说字典也可以是有序的,不要惊讶,那确实是真的
在Python3.6+中字典已经是有序的,并且效率相较之前的还有所提升,具体信息你可以去查询相关资料。
# Python3.6.7
>>> mydict = {str(i):i for i in range(5)}
>>> mydict
{'0': 0, '1': 1, '2': 2, '3': 3, '4': 4}
简洁而优雅的链式比较
先给你看一个示例:
>>> False == False == True
False
你知道这个表达式为什么会返回False吗?
它的运行原理与下面这个类似,是不是有点头绪了∶
if 80 < score <= 90:
print("成绩良好 ")
如果你还是不明白,那我再给你整个第一个例子的等价写法。
lse == False and False == True
False
这个用法叫做链式比较。
and和or的短路效应
and 和or是我们再熟悉不过的两个逻辑运算符,在Python 也有它有妙用。
·当一个or表达式中所有值都为真,Python会选择第一个值
·当一个and表达式所有值都为真,Python会选择第二个值。
示例如下∶
>>>(2 or 3) * (5 and 7)
14 # 2*7
连接多个列表最极客的方式
>>> a = [1,2]
>>> b = [3,4]
>>> c = [5,6]
>>>
>>> sum((a,b,c), []) [1, 2, 3, 4, 5, 6]