温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

关于Python中的三个秘密武器

发布时间:2020-07-03 15:18:22 来源:亿速云 阅读:254 作者:清晨 栏目:编程语言

这篇文章主要介绍关于Python中的三个秘密武器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

秘密武器#1:快速编码,少用Kite谷歌

大多数代码编辑器都具有类似这样的自动填充功能,...使用某种语言(库)文档来表明函数名和参数:

关于Python中的三个秘密武器

这不难,但如果编辑器可以浏览几年的GitHub数据,并且不仅仅能自动填充函数名称,还能完成整行代码呢?这仅是第一个使用Kite的理由。

原因 1:代码行填充

Kite访问代码库和各个变量、常用的在线参数名称以及文档后,会输出优质的语境建议:

关于Python中的三个秘密武器

上图示例展示了Kite如何能预测编码者需要使用的变量,即使它们一般被命名为(如b),或更普遍的名字(如x或y)。

Kite创始人兼首席执行官Adam Smith说:“我们在Github 上已经用了50多年的时间来对所有代码进行语义索引,构建统计类型推理,以及深度使用此语义信息的丰富统计模型。”

原因 2:在本地私密运行

最重要的是,它在本地运行,因此可以快速获得提示,离线也能工作,并且代码不会发送到云端。

对于网络情况异常和在闭信源代码库工作的人来说,这一点非常重要。

原因 3:文档编程助手

关于Python中的三个秘密武器

如果你从来没听过"RTFM"这个词,那可能因为没有在第一代开发者身边工作过。

向高级开发人员讨教是很有必要的,甚至去StackOverflow查找答案之前阅读文档。Kite Copilot让文档变得十分简单,其与编辑器同时运行,实时显示文档中光标掠过的任何对象/函数等。

结果

笔者使用Kite多年,它改进得也越来越好。其拥有超过1,700万美元的投资,不会轻易倒闭,而且它的工具是完全免费的。你只需要给编辑器下载Kite插件,或下载copilot(编码助手),就能安装插件。

关于Python中的三个秘密武器

秘密武器#2:用Mypy检查代码

编码Python 是动态的,简单解释就是:编码者可以随时将任何变量变为任何数据类型(字符串、整数等)。

# These two variable types aredeclared the exact same way
# Python figures out the data type on it's own, dynamically# string
var_name = "string here"# integer
var_name = 1234

相对的是静态类型的语言,其中它的变量必须有一个特定的数据类型,并且始终遵循它。

# Many languages require the datatype to be declared too# string
str var_name = "string here"# integer
int var_name = 1234

动态编码的优点/缺点

动态编码的优点是,你可以偷懒,并且能减少乱码。但它缺点很多且不小:

· 通常在开发周期后期会出现错误

· 由于Python不断计算类型,编码效果会降低

· 传递代码更不稳定,因为其他人可能不知道其中的变量是哪些或可能成为哪些数据类型

· 函数会更不稳定,因为它们的输入和输出可以在没有警告的情况下更改数据类型

关于Python中的三个秘密武器

Python 中的静态键入

打开Mypy,这是一个免费的Python模块,让你能在Python 内部静态编码。发出pip install mypy指令后, 下面就是其使用示例:

# Declaring a function using normaldynamic typing, without mypy
def iter_primes():
# code here# Declaring the samefunction with mypy static typing
from typing import Iteratordef iter_primes() -> Iterator[int]:
# code here

利用mypy 示例,能指定函数返还整数的迭代器。这种简单变化通过强制实施一致输出,使函数更具有预测性。

与仅使用文档不同,其他开发人员只需查看输出的将是什么数据类型,如果不符合该定义,则代码出错。

结果

列出静态类型以帮你减轻将来痛苦的所有方法有难度,但mypy文档具有出色的解答常见问题的能力,优缺点都不少。

如果你在一个把稳定性放在第一位的代码生产库工作,一定要试试myby。

关于Python中的三个秘密武器

秘密武器#3:用Sonarlint快速查找错误,编写更简单的函数

现在每个编辑器都有某种类型的错误检查或内置的"linter",可以用来查看代码,通常无需运行,并能预测可能存在的错误。这就是静态代码分析。

关于Python中的三个秘密武器

动态代码分析实际上尝试运行/编译代码的某些部分,以查看其是否正常工作,但它会自动在后台运行。它不是猜测,它事实上知道代码是否会出错,以及确切的错误是什么。

SonarLint是动态代码分析中最好的,有超多优点:

已注释或未命名的代码

对于代码库里满满的输出定义、已注释代码,以及未使用的函数,笔者十分愧疚。但正是如此,才会时刻警醒,留下深刻印象,方便查找。

不执行命令代码

与未命名的代码略有不同,不执行命令代码将会在编码者创建不可能评估时发出预警。这十分有必要,否则会导致进行几个小时的调试,这是笔者最喜欢的预警之一。

示例:

a = Noneif a == None or not a or a:
this_will_always_get_called()
else:
# sonarlint will warn you about thisline never being executed
this_will_never_get_called()

安全风险

代码库中的巨大数据库将不断实时更新安全风险,能警告使用者所面临的任何已知漏洞风险。

安全风险问题是小概率事件,基本不可能给我们留下印象。因此,每个人都应该行动起来持续追踪。SonarLint是一个伟大的开端。

关于Python中的三个秘密武器

认知复杂性

这个话题十分有趣,笔者可以针对它写一篇完整的文章。

简单解释就是,有人创建了一个数学公式,这个公式可以对代码的阅读/理解难易程度进行评分。

它非常有用,还易于理解。每次SonarLint要求编码者"降低认知复杂性"时,它都会对编码者的不规范操作简单解释,比如"无法定义,嵌套异常"。

以上是关于Python中的三个秘密武器的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI