$Python技巧大全
知乎上有一个问题:Python 有什么奇技淫巧?其中有各种不按套路出牌的招数,也不乏一些惊为天人的"奇技淫巧",会让你大呼:居然还有这种操作???
本文就是对日常使用过的或者觉得很精妙的"奇技淫巧"的归纳总结。
Python版问号表达式
x = 1
y = 2
print ('no','yes')[x==y]
no
这里巧妙地利用了Python会把False当做序列下标0、把True当做序列下标1的特性,把否定条件的输出放在前面的元组的第一个元素,而把肯定条件的输出放在第二个元素。又比如:
a = [1,2,3]
print a[False]
print a[True]
1
2
此时是不是一幅"黑人问号"脸呢?
列表的深度拷贝
a = [1,2,3]
b = a[:]
print id(a)
print id(b)
c = a
print id(c)
59952144
60485304
59952144
提到深度拷贝,是不是一下子就想起来了copy.deepcopy()函数了?但是对于列表来讲,深度拷贝根本不用那么麻烦,只需像上面那样:b = a[:]
即可实现,就是这么简单。
注:如果a是元组,这样玩是不可以的,切记!比如:
a = (1,2,3)
b = a[:]
print id(a)
print id(b)
59570456
59570456
可以看出a和b的id是相同的,那么就想还是乖乖用copy.deepcopy()来拷贝吧:
a = (1,2,3)
b = copy.deepcopy(a)
print id(a)
print id(b)
60481864
60481864
但是结果又让我们诧异了,这是因为元组是不可变对象,在内存中同一个元组只会存在一个,再怎么深度拷贝也没用(同为不可变对象的字符串也是同理的)。
在命令行启动一个本地服务器
python -m SimpleHTTPServer
打开系统命令行,输入上面这条命令,然后打开浏览器输入地址:http://localhost:8000/
,回车,将会看到命令行所在当前目录下的所有文件和文件夹,简直就是一个浏览器版的文件管理器。
把一个字符串写在多行
s = ('abc'
'de'
'fgh'
)
print s
abcdefgh
链式比大小
n = 1
print 0 < n < 5
print 9 > n < 5
print 0 > n < 5
print -1 > 0 < n < 5
True
True
False
False
动态导入包
d = __import__('json').loads('{"a":123,"b":"bbb"}')
print type(d)
print d
<type 'dict'>
{u'a': 123, u'b': u'bbb'}
注:动态导入包只在当前语句生效。
字典推导式
dic = {i:i ** 2 for i in xrange(5)}
print dic
{0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
见过列表推导式、生成器推导式,那么有没有见过字典推导式呢?上面就是一例。
快速反转字符串
s = '123456'
print s[::-1]
654321
优雅地打开文件
with open('test.txt','r') as f:
content = f.read()
用with语句上下文管理器可以自动地管理文件的打开、关闭,不需手工干预。
else,不止是else
普通用法
a = -1
if a > 0:
print 'big'
else:
print 'small'
small
循环语句搭配else
判断一个数是否是素数:
import math
n = 97
for i in range(2,int(math.sqrt(n) + 2)):
if n % i == 0:
print '{0} is not a prime!'.format(n)
break
else:
print '{0} is a prime!'.format(n)
97 is a prime!
可见,如果循环中有break语句,且直到循环结束都没有执行过break语句,那么就会继续走后面的else分支。
异常处理搭配else
try:
print 1/0
except Exception as msg:
print str(msg)
else:
print 'all is OK!'
integer division or modulo by zero
try:
print 1/1
except Exception as msg:
print str(msg)
else:
print 'all is OK!'
1
all is OK!
可见,如果没有发生异常,就会走else分支。
随机推荐
- 编程之美 set 3 最大公约数问题
解法 1. f(x,y) = f(y, y%x) (y>0) 辗转相除法 2. 取模运算较为耗时, 将取模变成相减. 但对极端数据效果很差, 比如 gcd(1000,1) 3. 分析公约数的特点 ...
- ORA-01102的解决办法
启动数据库时报错了! SQL> startup mount ORACLE instance started. Total System Global Area 608174080 bytes ...
- 【BZOJ2565】最长双回文串 Manacher
[BZOJ2565]最长双回文串 Description 顺序和逆序读起来完全一样的串叫做回文串.比如acbca是回文串,而abc不是(abc的顺序为“abc”,逆序为“cba”,不相同).输入长度为 ...
- 电力项目十四--js添加highslider特效
当页面的一个table表格无法显示所有的内容的时候,点击[查看详细信息],显示详细内容: 下载css,js 1.在actingIndex.jsp中添加:引入js和css: <LINK href= ...
- [C++] 跨平台的生成GUID方法
string GetGUID() { char szGUID[BUFF_SIZE]; #ifdef WIN32 GUID uuid; CoCreateGuid(&uuid); #else Tm ...
- Dealing with a Stream-based Transport 处理一个基于流的传输 粘包 即使关闭nagle算法,也不能解决粘包问题
即使关闭nagle算法,也不能解决粘包问题 https://waylau.com/netty-4-user-guide/Getting%20Started/Dealing%20with%20a%20S ...
- Period II---fzu1901(Next数组)
题目链接:http://acm.fzu.edu.cn/problem.php?pid=1901 给你一个字符串 s 求出所有满足s[i] == s[i+p] ( 0 < i+p < len ...
- virtio前端驱动详解
2016-11-08 前段时间大致整理了下virtIO后端驱动的工作模式以及原理,今天就从前端驱动的角度描述下目前Linux内核代码中的virtIO驱动是如何配合后端进行工作的. 注:本节代码参考Li ...
- Flask路由系统与模板系统
路由系统 @app.route('/user/<username>') @app.route('/post/<int:post_id>') @app.route('/post/ ...
- Java设计模式-简单工厂模式(Static Factory Method)
简单工厂模式(Static Factory Method) 简单工厂模式是类的创建模式,又叫静态工厂方法(Static Factory Method)模式.简单工厂模式是由一个工厂对象决定创建出哪一种 ...