下面是十个Python中颇有用的贴士和技巧。其中一些是初学这门语言经常会犯的错误。java
注意:假设咱们都用的是Python 3python
你有一个list:bag = [1, 2, 3, 4, 5]
web
如今你想让全部元素翻倍,让它看起来是这个样子:[2, 4, 6, 8, 10]
算法
大多初学者,根据以前语言的经验会大概这样来作django
bag = [1, 2, 3, 4, 5] for i in range(len(bag)): bag[i] = bag[i] * 2
可是有更好的方法:app
bag = [elem * 2 for elem in bag]
很简洁对不对?这叫作Python的列表推导式。编辑器
点击Trey Hunner’s tutorial查看更多关于列表推导式的介绍。函数
继续,仍是上面的列表。学习
若是可能尽可能避免这样作:测试
bag = [1, 2, 3, 4, 5] for i in range(len(bag)): bag[i] = bag[i] * 2
取而代之的应该是这样:
bag = [elem * 2 for elem in bag]
若是x是一个列表,你能够对它的元素进行迭代。多数状况下你不须要各元素的索引,但若是你非要这样作,那就用enumerate函数。它像下边的样子:
bag = [1, 2, 3, 4, 5] for i in range(len(bag)): print(bag[i])
很是直观明了。
若是你是从java或者C语言转到Python来,可能会习惯于这样:
a = 5 b = 10 # 交换 a 和 b tmp = a a = b b = tmp
但Python提供了一个更天然更好的方法!
a = 5 b = 10 # 交换a 和 b a, b = b, a
够漂亮吧?
假如你要一个是10个整数0的列表,你可能首先想到:
bag = [] for _ in range(10): bag.append(0)
换个方式吧:
bag = [0] * 10
看,多优雅。
注意:若是你列表包含了列表,这样作会产生浅拷贝。
举个例子:
bag_of_bags = [[0]] * 5 # [[0], [0], [0], [0], [0]] bag_of_bags[0][0] = 1 # [[1], [1], [1], [1], [1]]
Oops!全部的列表都改变了,而咱们只是想要改变第一个列表。
改一改啦:
bag_of_bags = [[0] for _ in range(5)] # [[0], [0], [0], [0], [0]] bag_of_bags[0][0] = 1 # [[1], [0], [0], [0], [0]]
同时记住:
“过早优化是万恶之源” 问问本身,初始化一个列表是必须的吗?
你会常常须要打印字符串。要是有不少变量,避免下面这样:
name = "Raymond" age = 22 born_in = "Oakland, CA" string = "Hello my name is " + name + "and I'm " + str(age) + " years old. I was born in " + born_in + "." print(string)
额,这看起来多乱呀?你能够用个漂亮简洁的方法来代替,.format。
这样作:
name = "Raymond" age = 22 born_in = "Oakland, CA" string = "Hello my name is {0} and I'm {1} years old. I was born in {2}.".format(name, age, born_in) print(string)
好多了!
tuples
(元组)Python容许你在一个函数中返回多个元素,这让生活更简单。可是在解包元组的时候出出线这样的常见错误:
def binary(): return 0, 1 result = binary() zero = result[0] one = result[1]
这是不必的,你彻底能够换成这样:
def binary(): return 0, 1 zero, one = binary()
要是你须要全部的元素被返回,用个下划线_:
zero, _ = binary()
就是这么高效率!
Dicts
(字典)你也会常常给dicts
中写入key,pair
(键,值)。
若是你试图访问一个不存在的于dict
的key
,可能会为了不KeyError
错误,你会倾向于这样作:
countr = {} bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7] for i in bag: if i in countr: countr[i] += 1 else: countr[i] = 1 for i in range(10): if i in countr: print("Count of {}: {}".format(i, countr[i])) else: print("Count of {}: {}".format(i, 0))
可是,用get()
是个更好的办法。
countr = {} bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7] for i in bag: countr[i] = countr.get(i, 0) + 1 for i in range(10): print("Count of {}: {}".format(i, countr.get(i, 0)))
固然你也能够用setdefault
来代替。
这还用一个更简单却多费点开销的办法:
bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7] countr = dict([(num, bag.count(num)) for num in bag]) for i in range(10): print("Count of {}: {}".format(i, countr.get(i, 0)))
你也能够用dict
推导式。
countr = {num: bag.count(num) for num in bag}
这两种方法开销大是由于它们在每次count
被调用时都会对列表遍历。
现有的库只需导入你就能够作你真正想作的了。
仍是说前面的例子,咱们建一个函数来数一个数字在列表中出现的次数。那么,已经有一个库就能够作这样的事情。
from collections import Counter bag = [2, 3, 1, 2, 5, 6, 7, 9, 2, 7] countr = Counter(bag) for i in range(10): print("Count of {}: {}".format(i, countr[i]))
一些用库的理由:
代码是正确并且通过测试的。 它们的算法可能会是最优的,这样就跑的更快。 抽象化:它们指向明确并且文档友好,你能够专一于那些尚未被实现的。 最后,它都已经在那儿了,你不用再造轮子了。
你能够指定start
的点和stop
点,就像这样list[start:stop:step]
。咱们取出列表中的前5个元素:
bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] for elem in bag[:5]: print(elem)
这就是切片,咱们指定stop
点是5,再中止前就会从列表中取出5个元素。
要是最后5个元素怎么作?
bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] for elem in bag[-5:]: print(elem)
没看明白吗?-5
意味着从列表的结尾取出5个元素。
若是你想对列表中元素间隔操做,你可能会这样作:
bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] for index, elem in enumerate(bag): if index % 2 == 0: print(elem)
可是你应该这样来作:
bag = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] for elem in bag[::2]: print(elem) # 或者用 ranges bag = list(range(0,10,2)) print(bag)
这就是列表中的步进。list[::2]
意思是遍历列表同时两步取出一个元素。
你能够用list[::-1]
很酷的翻转列表。
长时间来看,将tab和空格混在一块儿会形成灾难,你会看到IndentationError: unexpected indent
。无论你选择tab键仍是空格键,你应该在你的文件和项目中一直保持使用。
一个使用空格而不是tab的缘由是,tab不是在全部编辑器中都同样的。视呢所用的编辑器,tab可能会被看成2到8个空格。
你也能够在写代码时用空格来定义tab。这样你能够本身选择用几个空格来当作tab。大多数Python用户是用4个空格。
你们在学python的时候确定会遇到不少难题,以及对于新技术的追求,这里推荐一下咱们的Python学习扣qun:784758214,这里是python学习者汇集地!!同时,本身是一名高级python开发工程师,从基础的python脚本到web开发、爬虫、django、数据挖掘等,零基础到项目实战的资料都有整理。送给每一位python的小伙伴!每日分享一些学习的方法和须要注意的小细节