51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 804|回复: 0
打印 上一主题 下一主题

[转贴] 十个Python初学者常犯的错误

[复制链接]
  • TA的每日心情
    擦汗
    1 小时前
  • 签到天数: 1047 天

    连续签到: 5 天

    [LV.10]测试总司令

    跳转到指定楼层
    1#
    发表于 2022-7-27 09:49:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    下面10个Python初学者常犯的错误,并不是真正的代码错误,代码照样可以运行,但是不够Pythonic,因为Python有自己的语言哲学,在代码的处理上有传统语言无法比拟的简洁性和便捷性。
      1.  真值比较
      初学者经常在if语句中使用==比较符来判断表达式是否为真值。

    这是一种冗余的写法,其实你可以直接对变量进行检查。

    2 . 字符串连接
      很多初学者教程中,他们会告诉你字符串连接直接使用+操作符。

    一种更优雅的写法是使用f-string方式,将变量放置在{} 中,该方法能让代码清晰易读,因为你不需要针对非字符串变量做强制转换了。

    3. open()、close()与上下文管理器
      操作文件时,下面的代码看起来可读性很好,打开文件、编辑文件、关闭文件。不过在最后你总要是手动去调用close方法来关闭文件。

    其实python提供了内置的上下文管理器,操作文件时,使用with关键字操作文件,这样就不需要自己处理文件的关闭操作了,在离开上下文前管理器会自动帮你关闭文件。

    4. 检查列表是否为空
      假设你要基于列表做某些操作,操作前需要判断列表是否为空,初学者通常会使用len方法判断列表的长度是否为0,并做后续操作。

    有经验的开发者会告诉你,一种更好的方式是直接用列表本身来判断列表是否为空。

    5. 字典中获取key和value
      如果你要列出并打印字典中所有元素,首先你要拿到每个元素的key,然后通过key来获取对应的value。初学者通常将两个步骤分开处理。

    更便捷的方法是,字典的items()方法会返回一个由(key,value)元组构成的迭代对象。

    6. 解构赋值
      元组在python中是一种固定长度的数据结构,新手在将元组中的元素赋值给多个不同的变量时,他们通常的做法是从元组中逐个赋值给变量。

    更好的做法是直接在一行代码中用解构的方式,将元组同时赋值给多个不同的变量。

    7. 列表迭代
      对于新手来说,用for循环迭代列表中的元素时,他们通常的做法是先拿到列表的长度,然后通过元素的下标索引来获取值。

    其实更专业的做法就是直接迭代列表本身,每次迭代出来的值就是列表中的元素

    8.  一个索引用于多个列表
      假设你想将两个列表中的值做加操作,通常,你会从索引0开始循环直到列表的结尾,每次循环将列表项做加操作组成新的列表

    python提供了一个更好的方法zip(),它将两个列表对象重新组合成一个成对出现的tuple元素列表。

    9. 海象操作符
      在python3.8之前,当一个变量作用在if判断语句上时,要先给他赋值然后再处理

    python3.8的海象操作符,让你的代码减少重复,看起来更简洁,你可以将变量的赋值和if判断一行处理。

    10. 不必要的索引
      如果有一个文本列表,你想随下标索引一起打印,可以你单独定义一个数字变量每次迭代的时候递增1。

    一个更为专业的做法是直接用enumerate()方法,每次迭代时,他会返回元素的下标索引和元素本身。











    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有帐号?(注-册)加入51Testing

    x
    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏1
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-15 10:54 , Processed in 0.064340 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表