Python这些问题你会吗?
final作用域的代码一定会被执行吗?
正常的情况下,finally作用域的代码一定会被执行的,不管是否发生异常。哪怕是调用了sys.exit函数,finally也是会被执行的,那怎么样才能让finally代码不执行了。
import time
choice = True
try:
if choice:
while True:
pass
else:
print "Please pull the plug on your computer sometime soon..."
time.sleep(60 * 60 * 24 * 365)
finally:
print "Finally ..."
上面的代码主要是通过让流程停滞在try作用域里,从而实现了需求。上面的代码不排除有点投机取巧的意思,但是我们实习了题目的需求不是吗。
可以对含有任意的元素的list进行排序吗?
正常情况下:
>>> a = [1, '2', '3', '1']
>>> a.sort()
>>> a
[1, '1', '2', '3']
那是不是以为着,任何list都可以调用sort函数进行排序了?
>>> x = [1, 1j]
>>> x.sort()
Traceback (most recent call last):
File "<pyshell#13>", line 1, in ?
x.sort()
TypeError: cannot compare complex numbers using <, <=, >, >=
python里1j是一个特殊符号代表-1的平方根,出现这个问题的原因是sort函数调用的对象的__lt__函数来比较两个对象的,而复杂的数字类型是不可比较的,也就说没有实现__lt__函数,所以比较不了。因此,对于list里包含的对象如果都是可以比较的,也就是说实现了__lt__函数,那么对list调用sort函数是没问题的。
Python可是使用++x或者x++之类的操作吗?
- ++x操作是可以的,但是这个操作产生的结果和C语言里该操作产生的结果是不一样的,Python里++x操作里的加好只是一个一元操作符,所以,++x等价于+(+x),所以++x == x。
- x++操作是不合法的,虽然有些情况下,x++看着是合法的,比如:x++-y,但其实这个表达式等价于x+(+(-y)) = x-y,所以正常情况下,x++是不合法的。
Python里如何实现类似于C++里的cout<<x<<y操作?
实现的方法如下:
import sys
class ostream:
def __init__(self, file):
self.file = file
def __lshift__(self, obj):
self.file.write(str(obj));
return self
cout = ostream(sys.stdout)
cerr = ostream(sys.stderr)
nl = '\n'
cout << x << " " << y << nl
这地方并不是展示了一个新的python语法,这只是对python的str对象进行了封装。
Python里如何实现C++里的printf函数?
在python2中,print是一个表达式,python3里是个函数。所以在python2里,我们可以这么做:
def printf(format, *args): print format % args,
上面的代码虽然只有一行,但是,有些地方还是需要注意的。第一个地方,就是最后使用了都好结尾,这样的话会更像c++的printf函数,如果想换行,则需要传入换行符。第二个地方是这个代码会在最后多打印一个空格,如果不想要这个空格,可以使用sys.stdout.write函数。第三的方面,这行代码除了更像C++风格的printf,还有其他好处吗?当然是有的,参数是比较灵活的。
Python里逗号等号(,=)是什么意思?
你可以能见过下面的代码:
>>> x ,= range(1)
>>> x
0
实际上,没有逗号等号(,=)这种操作符,上面的代码等价于 (x,) = range(1)。
这只是一个赋值语句,在左边有一个元组,意味着将元组的每个元素赋给右边的相应元素; 在这种情况下,x被赋值为0
下面的代码是否意味着python里有阶乘的操作符?
比如下面的代码:
assert 0!=1
assert 3!=6
assert 4!=24
assert 5!=120
其实上面的代码并不是阶乘的结果,只是有意的构造代码的结果,实际上,上面的代码等价于:
assert 0 != 1
assert 3 != 6
assert 4 != 24
assert 5 != 120
这样一看,其实assert判断是不等于的关系,所以都是True。
如何快速的给Python的对象增加属性
通常我们的做法是,在对象定义的时候,定义相关的属性,那如何自由的添加对象属性了。
class Struct:
"A structure that can have any fields defined."
def __init__(self, **entries): self.__dict__.update(entries)
>>> options = Struct(answer=42, linelen=80, font='courier')
>>> options.answer
42
>>> options.answer = 'plastics'
>>> vars(options)
{'answer': 'plastics', 'font': 'courier', 'linelen': 80}
如何定义一个包含默认值的dict
在python2.7之前,必须定义一个类来处理这样的需求,现在,可以使用collections.defaultdict和collections.Counte来实现。
from collections import Counter
words = 'this is a test this is only a test'.split()
>>> Counter(words)
Counter({'this': 2, 'test': 2, 'a': 2, 'is': 2, 'only': 1})
如何计算函数的执行时间
def timer(fn, *args):
"Time the application of fn to args. Return (result, seconds)."
import time
start = time.clock()
return fn(*args), time.clock() - start
>>> timer(max, range(1e6))
(999999, 0.4921875)
当然,python还有很多现成的轮子,可以更好的计算程序每个步骤的详细信息。
如何实现单例模式
网上有很多方法,但是我知道的最简单的方式如下:
def singleton(object):
"Raise an exception if an object of this class has been instantiated before."
cls = object.__class__
if hasattr(cls, '__instantiated'):
raise ValueError("%s is a Singleton class but is already instantiated" % cls)
cls.__instantiated = True
class YourClass:
"A singleton class to do something ..."
def __init__(self, args):
singleton(self)
...