设为首页 收藏本站
查看: 4137|回复: 0

[经验分享] 让你的代码符合PEP8标准——sublime text 2 安装及使用 Python Flake8 Lint 插件

[复制链接]

尚未签到

发表于 2015-4-26 05:49:07 | 显示全部楼层 |阅读模式
  上周看到一个招Python工程师的要求,其中有一条就是要求代码符合PEP8标准。
  PEP8标准之前就听说过,是Python官方推荐的一个代码标准。并不是强制要求,只是推荐大家使用,增加代码可读性。
  因为我的代码一直都是自己写自己看,所以也就没有考虑PEP8。不过看到这个招聘要求,感觉自己还是应该学习一下,毕竟以后代码会有别人看,规范一点方便自己也方便他人嘛。
  一、PEP8标准
  首先了解一下什么是PEP8标准吧。
  点击这里可以查看官方的PEP8详细要求。是英文版,大家如果阅读起来比较吃力的话可以自己去搜中文版。
  看完标准之后,大家会发现,具体细节要求非常多。。。对于一个初次接触PEP8标准的人来说,如果只靠自己的判断来修改的话不仅不准确而且效率很低,所以我们自然就想到了使用插件。
  二、安装及配置Python Flake8 Lint插件
  我使用的是sublime text 2,这个编辑器挺对我胃口的,所以就去github上找了一下sublime text 2上的PEP8插件。找了有两三个吧,最后准备使用:
  Python Flake8 Lint
  下面就说一下安装步骤吧。
  首先,点击页面中的 DSC0000.png 按钮下载ZIP压缩包,然后解压并把文件夹的名字改为:Python Flake8 Lint 。
  改完名之后,按照你使用的系统把这个文件夹复制到对应的路径里:

  • OS X:
  ~/Library/Application Support/Sublime Text 2/Packages/


  • Linux:
  ~/.config/sublime-text-2/Packages/


  • Windows:
  %APPDATA%/Sublime Text 2/Packages/
  我用的是mac,所以就复制到“~/Library/Application Support/Sublime Text 2/Packages/”这个目录当中。
  复制好之后,打开st2,点击"Preferences" -> "Package Settings" -> "Python Flake8 Lint" -> "Settings - Default",会自动打开一个文件。我们把这个文件的内容全选然后复制,然后打开"Preferences" -> "Package Settings" -> "Python Flake8 Lint" -> "Settings - User",会自动打开一个空文件,我们把刚才复制的内容粘贴进去,这时候就可以进行设置了。

  具体的设置我就不介绍了,大家看注释就明白了,我说一下ignore这项吧。
  因为我不太赞同PEP8里关于一行不超过79个字符的规定,所以我决定忽略这条规则。于是我在ignore后面的[]中加上对应的编号W191(后面讲如何获取编号),这时代码变成了 "ignore": ["W191"], 保存之后就可以生效了。
  对了,因为不需要flake8的检测,所以我把"pyflakes": false,这个设置成了false。
  三、插件的使用
  插件的使用很简单,有两种方式触发。第一种是保存的时候会自动触发,第二种是按下“ctrl+花键+8(mac)”或者“ctrl+alt+8”来触发。
  触发之后会自动检测代码,如果有不符合PEP8的地方会出现一个列表框,如图:
   DSC0001.png
  大家可以看到中间那个列表框就是错误信息。
  前面说到一行79个字符对应的编号是W191,这里就要揭秘这个编号是怎么来的了。
  其实很简单,大家看列表框里错误信息的开头,看到了吧~~~那个就是对应的编号。
  你想忽略哪一条就把对应的编号加入到ignore里就可以了。
  如果大家对错误信息不是很清楚的话可以结合PEP8标准来看,基本上信息已经很清楚了,照着改就好了。
  
  还有一个小技巧:点击错误信息会自动跳转到那一行。
  四、总结
  这个插件还是挺好用的,挺方便。
  我安装上之后,用了一个小时时间把我的浪漫1点的Python代码全部改成了符合PEP8标准的代码,感觉看起来确实舒服了很多。
  以后的Python项目准备全部符合PEP8标准。
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-60613-1-1.html 上篇帖子: eric4 安装的中文支持问题(乱码)—python笔记 下篇帖子: python 获取外网ip
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

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