Python编程语言中有哪些鲜为人知但很有用的特性?
尽量将答案限制在Python核心。
每个回答一个特征。
给出一个例子和功能的简短描述,而不仅仅是文档链接。
使用标题作为第一行标记该特性。
快速链接到答案:
参数解包
牙套
链接比较运算符
修饰符
可变默认参数的陷阱/危险
描述符
字典默认的.get值
所以测试
省略切片语法
枚举
其他/
函数作为iter()参数
生成器表达式
导入该
就地值交换
步进列表
__missing__物品
多行正则表达式
命名字符串格式化
嵌套的列表/生成器推导
运行时的新类型
.pth文件
ROT13编码
正则表达式调试
发送到发电机
交互式解释器中的制表符补全
三元表达式
试着/ / else除外
拆包+打印()函数
与声明
脚本的交互式调试(和doctest字符串)
我不认为这是广为人知的,但添加这一行到任何python脚本:
进口pdb;pdb.set_trace ()
将导致PDB调试器在代码的那一点弹出运行游标。我想,更鲜为人知的是,你可以在doctest中使用同样的行:
"""
>>> 1 in (1,2,3)
Becomes
>>> import pdb; pdb.set_trace(); 1 in (1,2,3)
"""
然后可以使用调试器检出doctest环境。您不能真正逐级执行doctest,因为每一行都是自主运行的,但它是调试doctest glob和环境的好工具。
按以下方式访问字典元素
属性(属性)。所以如果
a1=AttrDict()有键'name' ->
而不是a1['name'],我们可以很容易
使用->访问a1的名称属性
a1.name
class AttrDict(dict):
def __getattr__(self, name):
if name in self:
return self[name]
raise AttributeError('%s not found' % name)
def __setattr__(self, name, value):
self[name] = value
def __delattr__(self, name):
del self[name]
person = AttrDict({'name': 'John Doe', 'age': 66})
print person['name']
print person.name
person.name = 'Frodo G'
print person.name
del person.age
print person
创建生成器对象
如果你写
x=(n for n in foo if bar(n))
你可以取出生成器,把它赋值给x,这意味着你可以这样做
for n in x:
这样做的优点是不需要中间存储,如果需要中间存储,则需要中间存储
x = [n for n in foo if bar(n)]
在某些情况下,这可以显著提高速度。
你可以在生成器的末尾附加许多if语句,基本上复制嵌套的for循环:
>>> n = ((a,b) for a in range(0,2) for b in range(4,6))
>>> for i in n:
... print i
(0, 4)
(0, 5)
(1, 4)
(1, 5)
我不确定这在Python文档中的位置(或是否),但对于Python 2。x(至少2.5和2.6,我刚刚尝试过),打印语句可以用括号调用。如果您希望能够轻松地移植一些Python 2,这可能很有用。Python 3.x代码。
例子:
我们想要Moshiach Now在python 2.5, 2.6和3.x中工作。
此外,在Python 2和3中,not操作符可以用括号调用:
不是假的
而且
(假)
都应该返回True。
括号也可以用于其他语句和操作符。
编辑:把括号放在非操作符(可能是任何其他操作符)周围不是一个好主意,因为它会导致令人惊讶的情况,就像这样(发生这种情况是因为括号实际上只是在1周围):
>>> (not 1) == 9
False
>>> not(1) == 9
True
这也可以工作,对于某些值(我认为它不是一个有效的标识符名称),像这样:
not'val'将返回False, print'We want Moshiach Now'将返回We want Moshiach Now。(但是not552会引发NameError,因为它是一个有效的标识符名称)。
切片和可变性
复制清单
>>> x = [1,2,3]
>>> y = x[:]
>>> y.pop()
3
>>> y
[1, 2]
>>> x
[1, 2, 3]
替换列表
>>> x = [1,2,3]
>>> y = x
>>> y[:] = [4,5,6]
>>> x
[4, 5, 6]