1 在作比较时你可以这样写: 3.14<pi<3.15,它得到的结果和(pi>3.14 and pi<3.15)是一样的,在大多数其他语言里,你都不能用这么自然的语法了。 2 Int类型不会在超过31bit或32bit后溢出,它们会变成long型。在 python里,long并非就是64位,他就是"长"类型,(python的长类型可以容纳数万位大的整数),效率会降低一点。在python 3000中,甚至连int与long的区别都没有了。 3默认值只会在编译时被赋值一次,而非运行时。试试这个: def func (a[]): a.append(42); 返回值a会随调用不断加入42. python的教程里有更多相关的讨论。 4 连接多个字符串时,"".join(list)会比 for x in list: s+=x快得多。实际上 join调用复杂度是o(n),而+=是o(n2).有很多人要求使这个调用更快,而且python2.5里似乎也应该变得更快了,但我的测试结果 却并非如此,有谁知道为什么吗? 5 语法 print >>file里,仅数值被写入文件中,而print的格式化功能不起作用。我很高兴听到他们说在python 3000总,print会变成一个函数,而且带有了更多高级的特性。 6 你可以通过(x,)来创建只有一个元素的tuple,通常你只能建立如 (x,y,z)那样的tuple,如果你想通过(x)来建立一个tuple,得到的只是x 7如果你想看看整数类的帮助文档,你可以写(5).__str__; 你不能简化成5.__str__,因为解释器会把5.认作是浮点数,然后出错了。 8你可以使用属性而不是getter或setter函数。例如serial. baudrate=192000 可以设置serial._baud,跟你调用其它调用的效果一样。 9 一个紧跟在for循环后的else语句只有在循环不通过break退出时才会被调用。这对查找循环很有用处,通常这样的循环都会需要在退出后作 额外的检查判断。 10 |
判断字典存不存在key 用 if key in _dict: ...cost time : 0.000270260584074 比 if key in _dict.keys(): ...cost time : 0.05606396371 效率高... 上面是1000000数据测试 11 |
a = 1
|
b = 2 #如何交接两个变量的值: |
a,b = b,a
|
''' 去除重复元素 ''' |
12 l1 = ['b','c','d','b','c','a','a'] l2 = list(set(l1)) print l2 l3 = [('a','b','dddd'), ('a','b','dddd'),('a','b','dddd1')] print {}.fromkeys(l3).keys() |
|