Python是一种功能强大的解释型编程语言。我们可以通过下面的10条优化技巧来减少代码量并提高代码的运行效率。
问题:输出1万内每个数的平方。 发现用列表推导式所用时间更少。
from timeit import default_timer as timer
start = timer()
square =[]
for n in range(10000):
square.append(pow(n,2))
end = timer()
print("优化前耗时:",end - start)
#优化后
start2=timer()
square=[pow(n,2) for n in range(10000)]
end2=timer()
print("优化后耗时:",end2 - start2)
print(square)
如果对1万内每个数的平方求和,换用Python生成器来存储过程数据,我们发现占用的内存更少。
import sys
square = [n**2 for n in range(10000)]
print(sum(square))
print(sys.getsizeof(square),'字节') #优化后
square = (n\*\*2 for n in range(10000))
print(sum(square))
print(sys.getsizeof(square),'字节')
lst=[20, 40, 20, 20, 40, 60, 70]
print(sorted(list(lst),reverse=True))
lst=[20, 40, 20, 20, 40, 60, 70]
# print(sorted(list(lst),reverse=True))
print(set(lst))
dogs = ['Harley', 'Phantom', 'Lucky', 'Dingo']
count = 1
for name in dogs:
print(count, name)
count += 1
#优化后
print('优化后')
for i,name in enumerate(dogs,start=1):
print(i,name)
roman_nums = {'I':1, 'II':2, 'III':3, 'IV':4 }
# value=roman_nums['V'] # 访问不存在的键值会报错 KeyError: 'V'
value=roman_nums.get('V',5)
print('value=',value)
print(roman_nums)
value = roman_nums.setdefault('V',5)
print(roman_nums)
#统计出现次数最多的元素
#首先引入该方法
from collections import Counter
s='hello'
print(Counter(s))
#法二
print([(x,s.count(x)) for x in set(s)])
name,major = "world","computer science"
s="Hello, %s. I major in %s." % (name,major)
s1="Hello, {}. I major in {}.".format(name, major)
s2=f"Hello, {name}. I major in {major}." #推荐用法
print(s,s1,s2,sep='\n')
s=['H','e','l','l','o']
s1=''
for x in s:
s1+=x
print(s1)
s1=''.join(s)#推荐用法
print(s1)
#法一
x = {'a': 1, 'b': 2}
y = {'b': 10, 'c': 11}
x.update(y)
print(x)
#法二 Python3.9+
z = x | y
print(z)
#法三 Python3.5+
z = {**x, **y}
print(z)
#法四
z = dict(list(x.items()) + list(y.items()))
print(z)
如果喜欢,不忘了在微信文章的下面一键三连(分享,点赞和收藏)。关注微信公众号“乐享Python”。