程序员写Python时的5个坏习惯,你有几条?

yipeiwu_com5年前Python基础

很多文章都有介绍怎么写好 Python,我今天呢,相反,说说写代码时的几个坏习惯。有的习惯会让 Bug 变得隐蔽难以追踪,当然,也有的并没有错误,只是个人觉得不够优雅。

注意:示例代码在 Python 3.6 环境下编写

1 用列表作函数的默认参数

看下面这个例子

def func(a, b=[]): 
   b.append(a) 
   print(f'a: {a}') 
   print(f'b: {b}') 
 func(1) 
 func(2) 

正常我们期望的结果应该是这样的

a: 1 
  b: [1] 
  a: 2 
  b: [2] 

但当我们执行代码后,只会得到这样的结果

a: 1 
  b: [1] 
  a: 2 
  b: [1, 2] 

与预期不一致。为什么呢?因为 Python 列表是可变对象,而且函数传参又是传的引用,所以当第二次调用 func 方法前,b 中已经有了元素 1,调用后 b 最终有两个元素 1 和 2。

示例中 func 方法比较简单,当发现问题的时候简单看下就能找到根源。但是,如果是在一个比较复杂的方法里面,你有可能会粗心的忽略这一点,从而会碰到一些莫名其妙的问题。

所以,当我们要为函数设置默认参数的时候,不要使用可变对象。

上面的代码改成这样就 OK 了

def func(a, b=None): 
   if b is None: 
     b = [] 
   b.append(a) 
   print(f'a: {a}') 
   print(f'b: {b}') 

执行后得到预期结果

a: 1 
  b: [1] 
  a: 2 
  b: [2] 

2 文件操作

很多刚接触 Python 的伙伴做文件操作的时候很容易写类似的代码

file = open('file_name') 
  try: 
    for line in file: 
      print(line) 
  finally: 
    file.close() 

这没有问题,不过文件资源我们没有必要手动去维护,像关闭这样的操作交给上下文管理器做就好。

with open('file_name') as file: 
    for line in file: 
      print(line) 

这样看起来不是清爽很多。

3 捕获所有异常

try: 
    pass # 做一些操作 
  except Exception as e: 
    print(f'Exception {e}') 

就像上面一样,有时我们为了能够快速的完成功能,很容易不管三七二十一,就捕获 Exception 异常。这可能会捕捉到键盘中断(KeyboardInterrupt)(CTRL + C)或断言错误(AsstionError)等异常。捕获不确定的异常,有时也会让我们的程序出现莫名其妙的问题,我们应该避免这样做。

准确的做法是根据上下文捕获 ValueError 、AttributeError 、TypeError 等比较具体的异常,然后做适当的错误处理,比如打印日志等。

4 忽略 Python 的 for...else 语法

开发中我们很容易碰到类似的需求,在一个列表中,确定某个特定的元素是否存在。比如,下面的代码便是确定列表中有没有奇数存在

numbers = [1, 2, 3, 4, 5] 
 is_odd_exist = False 
 for n in numbers: 
   if n % 2 == 1: 
     is_odd_exist = True 
     break 
 if is_odd_exist: 
   print('Odd exist') 
 else: 
   print('Odd not exist') 

这里,我们使用了一个标识 is_odd_exist,默认为 False。当找到奇数时,将其置为 True,然后跳出循环。这样写并没有问题,但是我们可以换种方式

numbers = [1, 2, 3, 4, 5] 
  for n in numbers: 
    if n % 2 == 1: 
      print('Odd exist') 
      break 
  else: 
    print('Odd not exist') 

先介绍下 Python 的 for...else 语法,当 for 循环是正常结束时(即不是通过 break 跳出结束的),会执行 else 中的语句。

这里,我们使用了相对于其他语言如 C、PHP 等不同的一种方式,完成了相同的功能,看起来代码也简洁了不少。

5 使用键遍历字典

初学 Python 的伙伴,可能容易写出这样的代码

member = {'name': 'xiaoming', 
       'age': 18, 
       'mobile': '18312341234'} 
  for key in member: 
    print(f'{key}: {member[key]}') 

同样,这也是没有问题的,但看起来并不直观。字典遍历的时候,其实可以直接取出键值信息,像这样

member = {'name': 'xiaoming', 
      'age': 18, 
      'mobile': '18312341234'} 
 for key, val in member.items(): 
   print(f'{key}: {val}') 

这样的话,看起来要明了一些。

总结

以上所述是小编给大家介绍的程序员写Python时的5个坏习惯,你有几条?希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对【听图阁-专注于Python设计】网站的支持!

相关文章

Python自动扫雷实现方法

本文实例讲述了Python自动扫雷实现方法。分享给大家供大家参考。具体如下: #pyWinmineCrack.py # coding: utf-8 import win32gui i...

深入浅析Python获取对象信息的函数type()、isinstance()、dir()

深入浅析Python获取对象信息的函数type()、isinstance()、dir()

type()函数: 使用type()函数可以判断对象的类型,如果一个变量指向了函数或类,也可以用type判断。 如: class Student(object): name = '...

浅谈pyhton学习中出现的各种问题(新手必看)

目前比较杂乱无章,后续还会有一些添加补充 1、标识符 (1)标识符是区分大小写的。 (2)标示符以字母或下划线开头,可包括字母,下划线和数字。 (3)以下划线开头的标识符是有特殊意义的。...

python用于url解码和中文解析的小脚本(python url decoder)

复制代码 代码如下: # -*- coding: utf8 -*- #! python print(repr("测试报警,xxxx是大猪头".decode("UTF8").encode(...

python快速编写单行注释多行注释的方法

python快速编写单行注释多行注释的方法

在python代码编写过程中,养成注释的习惯非常有用,可以让自己或别人后续在阅读代码时,轻松理解代码的含义。 如果只是简单的单行注释,可直接用“#”号开头,放于代码前面。 单行注释也可...