好的做法:
def mutable_default_arguments():
def append(n, l=None):
if l is None:
l = []
l.append(n)
return l
l1 = append(0) # [0]
l2 = append(1) # [1]
6、从不用推导式
坏的做法
squares = {}
for i in range(10):
squares[i] = i * i
好的做法
odd_squares = {i: i * i for i in range(10)}
7、推导式用的上瘾
推导式虽然好用,但是不可以牺牲可读性,坏的做法
c = [
sum(a[n * i + k] * b[n * k + j] for k in range(n))
for i in range(n)
for j in range(n)
]
好的做法:
c = []
for i in range(n):
for j in range(n):
ij_entry = sum(a[n * i + k] * b[n * k + j] for k in range(n))
c.append(ij_entry)
8、检查类型是否一致用 ==
坏的做法
def checking_type_equality():
Point = namedtuple(‘Point’, [‘x’, ‘y’])
p = Point(1, 2)
if type§ == tuple:
print(“it’s a tuple”)
else:
print(“it’s not a tuple”)
好的做法
def checking_type_equality():
Point = namedtuple(‘Point’, [‘x’, ‘y’])
p = Point(1, 2)
probably meant to check if is instance of tuple
if isinstance(p, tuple):
print(“it’s a tuple”)
else:
print(“it’s not a tuple”)
9、用 == 判断是否单例
坏的做法
def equality_for_singletons(x):
if x == None:
pass
if x == True:
pass
if x == False:
pass
好的做法
def equality_for_singletons(x):
better
if x is None:
pass
if x is True:
pass
if x is False:
pass
10、判断一个变量用 bool(x)
坏的做法
def checking_bool_or_len(x):
if bool(x):
pass
if len(x) != 0:
pass
好的做法
def checking_bool_or_len(x):
usually equivalent to
if x:
pass
11、使用类 C 风格的 for 循环
坏的做法
def range_len_pattern():
a = [1, 2, 3]
for i in range(len(a)):
v = a[i]
…
b = [4, 5, 6]
for i in range(len(b)):
av = a[i]
bv = b[i]
…
好的做法
def range_len_pattern():
a = [1, 2, 3]
instead
for v in a:
…
or if you wanted the index
for i, v in enumerate(a):
…
instead use zip
for av, bv in zip(a, b):
…
12、不实用 dict.items
坏的做法
def not_using_dict_items():
d = {“a”: 1, “b”: 2, “c”: 3}
for key in d:
val = d[key]
…
好的做法
def not_using_dict_items():
d = {“a”: 1, “b”: 2, “c”: 3}
for key, val in d.items():
…
13、解包元组使用索引
坏的做法
mytuple = 1, 2
x = mytuple[0]
y = mytuple[1]
好的做法
mytuple = 1, 2
x, y = mytuple
14、使用 time.time() 统计耗时
坏的做法
def timing_with_time():
start = time.time()
time.sleep(1)
end = time.time()
print(end - start)
好的做法是使用 time.perf_counter(),更精确:
def timing_with_time():
more accurate
start = time.perf_counter()
time.sleep(1)
end = time.perf_counter()
print(end - start)
15、记录日志使用 print 而不是 logging
坏的做法
def print_vs_logging():
print(“debug info”)
print(“just some info”)
print(“bad error”)
好的做法
def print_vs_logging():
versus
in main
level = logging.DEBUG
fmt = ‘[%(levelname)s] %(asctime)s - %(message)s’
logging.basicConfig(level=level, format=fmt)
wherever
logging.debug(“debug info”)
logging.info(“just some info”)
logging.error(“uh oh 😦”)
最后
🍅 硬核资料:关注即可领取PPT模板、简历模板、行业经典书籍PDF。
🍅 技术互助:技术群大佬指点迷津,你的问题可能不是问题,求资源在群里喊一声。
🍅 面试题库:由技术群里的小伙伴们共同投稿,热乎的大厂面试真题,持续更新中。
🍅 知识体系:含编程语言、算法、大数据生态圈组件(Mysql、Hive、Spark、Flink)、数据仓库、Python、前端等等。
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!