Python小技巧和有趣的内置函数
一个python小技巧的集合和一些很有用的Python内置函数,这些函数简直是屌爆了,我认为每个 Pythoner 都应该知道这些函数。
1.1 拆箱
1 | >>> a, b, c = 1, 2, 3 |
1.2 拆箱变量交换
1 | >>> a, b = 1, 2 |
1.3 扩展拆箱(只兼容python3)
1 | >>> a, *b, c = [1, 2, 3, 4, 5] |
1.4 负数索引
1 | >>> a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10] |
1.5 切割列表
1 | >>> a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10] |
1.6 负数索引切割列表
1 | >>> a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10] |
1.7指定步长切割列表
1 | >>> a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10] |
1.8 负数步长切割列表
1 | >>> a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10] |
1.9 列表切割赋值
1 | >>> a = [1, 2, 3, 4, 5] |
1.10 命名列表切割方式
1 | >>> a = [0, 1, 2, 3, 4, 5] |
1.11 列表以及迭代器的压缩和解压缩
1 | >>> a = [1, 2, 3] |
1.12 列表相邻元素压缩器
1 | >>> a = [1, 2, 3, 4, 5, 6] |
1.13 在列表中用压缩器和迭代器滑动取值窗口
1 | >>> def n_grams(a, n): |
用压缩器反转字典
1 | >>> m = {'a': 1, 'b': 2, 'c': 3, 'd': 4} |
1.15 列表展开
1 | >>> a = [[1, 2], [3, 4], [5, 6]] |
1.16 生成器表达式
1 | >>> g = (x ** 2 for x in xrange(10)) |
1.17 字典推导
1 | >>> m = {x: x ** 2 for x in range(5)} |
1.18 用字典推导反转字典
1 | >>> m = {'a': 1, 'b': 2, 'c': 3, 'd': 4} |
1.19 命名元组
1 | >>> Point = collections.namedtuple('Point', ['x', 'y']) |
函数部分
all(iterable)
如果可迭代的对象(数组,字符串,列表等,下同)中的元素都是true(或者为空)的话返回True
1 | _all = True |
更简便的写法是:
1 | if all(iterable): |
any(iterable)
如果可迭代的对象中任何一个元素为true的话返回True,如果可迭代的对象为空则返回False
1 | _any = False |
更简便的写法是:
1 | if any(iterable): |
cmp(x, y)
比较两个对象 x 和 y , x < y 的时候返回负数, x ==y 的时候返回 0, x > y 的时候返回正数
1 | def compare(x,y): |
你完全可以使用一句 cmp(x, y) 来替代。
dict([arg])
使用 arg 提供的条目生成一个新的字典。
arg 通常是未知的,但是它很方便!比如说,如果我们想把一个含两个元组的列表转换成一个字典,我们可以这么做。
1 | l = [('Knights', 'Ni'), ('Monty', 'Python'), ('SPAM', 'SPAAAM')] |
或者这样:
1 | l = [('Knights', 'Ni'), ('Monty', 'Python'), ('SPAM', 'SPAAAM')] |
enumerate(iterable [,start=0])
我真的是超级喜欢这个!如果你以前写过C语言,那么你可能会这么写:
1 | for i in range(len(list)): |
噢,不用那么麻烦!你可以使用enumerate()来提高可读性。
1 | for i, item in enumerate(list): |
isinstance(object, classinfo)
如果 object 参数是 classinfo 参数的一个实例或者子类(直接或者间接)的话返回 True
当你想检验一个对象的类型的时候,第一个想到的应该是使用type()函数
1 | if type(obj) == type(dict): |
或者你可以这么写
1 | if isinstance(obj, dict): |
pow(x, y [,z])
返回 x 的 y 次幂(如果 z 存在的话则以 z 为模)。
如果你想计算 x 的 y 次方,以 z 为模,那么你可以这么写:
1 | mod = (x ** y) % z |
但是当 x=1234567, y=4567676, z=56 的时候我的电脑足足跑了 64 秒!
不要用 ** 和 % 了,使用 pow(x, y, z) 吧!这个例子可以写成 pow(1234567, 4567676, 56) ,只用了 0.034 秒就出了结果!
zip([iterable, ])
这个函数返回一个含元组的列表,具体请看例子:
1 | l1 = ('You gotta', 'the') |
或者这么写:
1 | l1 = ['You gotta', 'the'] |
如果你想得到倒序的话加上 * 操作符就可以了:
1 | print zip(*out) |
结论
Python 内置函数很方便,它们很快并且经过了优化,所以它们可能效率更高。
我真心认为每个 Python 开发者都应该好好看看内置函数的文档(引言部分)。
忘了说了,在 itertools 模块中有很多很不错的函数。