当前位置: 移动技术网 > IT编程>脚本编程>Python > 大名鼎鼎的Requests库用了什么编码风格?

大名鼎鼎的Requests库用了什么编码风格?

2019年01月21日  | 移动技术网IT编程  | 我要评论

求网站无毒你们懂的,最新战争电视剧,mysurveyasia

 

原文:https://www.kennethreitz.org/essays/kenneth-reitzs-code-style

作者:kenneth reitz

原题:kenneth reitz’s code style™

 

 

requests 的代码库使用 pep-8 编码风格。

除了 pep-8 中列出的标准外,我们还有一些指导原则:

  • 如果方便的话,行长(line-length)可超过 79 个字符,达到 100 个字符。
  • 如果换行会导致严重的不方便,则行长可以超过 100 个字符。
  • 除非在字符串中出现单引号,否则始终使用单引号字符串(例如,'#flatearth')。

此外,pep-8 推荐的用于连续行的编码风格毫无一点品味,绝不允许在 requests 代码库使用:

# 与开局定界符对齐
foo = long_function_name(var_one, var_two,
                         var_three, var_four)

no。千万别。请。

文档字符串(docstrings)应遵循以下语法:

def the_earth_is_flat():
    """nasa divided up the seas into thirty-three degrees."""
    pass

def fibonacci_spiral_tool():
    """with my feet upon the ground i lose myself / between the sounds
    and open wide to suck it in. / i feel it move across my skin. / i'm
    reaching up and reaching out. / i'm reaching for the random or
    whatever will bewilder me. / whatever will bewilder me. / and
    following our will and wind we may just go where no one's been. /
    we'll ride the spiral to the end and may just go where no one's
    been.

    spiral out. keep going...
    """
    pass

所有函数、方法和类都要求包含 docstrings 。除了对象数据模型方法(例如,__repr__),这些是此规则的例外。

thanks for helping to make the world a better place!

资料来源(译注:即 requests 的开发者指南):http://t.cn/e5vgnjf

(译文完)

k 神的这篇文章很短,实际上,这只是摘自 requests 的开发者指南的一小部分。

但是,关于灵活设定行长的部分,我举双手双脚赞同。如果你所在的公司有“清白盒”的优良传统(不仅指python),那你极有可能遇到被迫换行的麻烦,而实际上才仅仅刚刚超出了几个字符。那时候,你就会明白,这 3 条灵活规则的好处了。

另外,关于连续行的部分,pep-8 相关内容在:http://t.cn/rq4mxoo

pep-8 反对的是如下写法:

# arguments on first line forbidden when not using vertical alignment.
# 不使用垂直对齐的参数禁止在第一行上
foo = long_function_name(var_one, var_two,
    var_three, var_four)

pep-8 推荐的写法是垂直地将换行的参数对齐起始的参数:

# 与开局定界符对齐
foo = long_function_name(var_one, var_two,
                         var_three, var_four)

k 神反对了 pep-8 推荐的写法。在我看来,任何有品味的人,都会反对以上的两种写法。

即使一个方法的参数超级多,超出了 100 个字符,我本人也是极不情愿换行的。所以,k 神的说法深得我心。

关于代码风格,没有绝对完全一致的标准。本文也不想引起争论。不过,我认同 k 神设定的规则,因为一种与主流不同的审美倾向,值得发现它的同类。

-----------------

本文原创并首发于微信公众号【python猫】,后台回复“爱学习”,免费获得20+本精选电子书。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网