关于Python中的三个秘密武器-创新互联
创新互联www.cdcxhl.cn八线动态BGP香港云服务器提供商,新人活动买多久送多久,划算不套路!
创新互联是一家专注于成都网站建设、网站制作与策划设计,九龙坡网站建设哪家好?创新互联做网站,专注于网站建设10多年,网设计领域的专业建站公司;建站业务涵盖:九龙坡等地区。九龙坡做网站价格咨询:18982081108这篇文章主要介绍关于Python中的三个秘密武器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
秘密武器#1:快速编码,少用Kite谷歌
大多数代码编辑器都具有类似这样的自动填充功能,...使用某种语言(库)文档来表明函数名和参数:
这不难,但如果编辑器可以浏览几年的GitHub数据,并且不仅仅能自动填充函数名称,还能完成整行代码呢?这仅是第一个使用Kite的理由。
原因 1:代码行填充
Kite访问代码库和各个变量、常用的在线参数名称以及文档后,会输出优质的语境建议:
上图示例展示了Kite如何能预测编码者需要使用的变量,即使它们一般被命名为(如b),或更普遍的名字(如x或y)。
Kite创始人兼首席执行官Adam Smith说:“我们在Github 上已经用了50多年的时间来对所有代码进行语义索引,构建统计类型推理,以及深度使用此语义信息的丰富统计模型。”
原因 2:在本地私密运行
最重要的是,它在本地运行,因此可以快速获得提示,离线也能工作,并且代码不会发送到云端。
对于网络情况异常和在闭信源代码库工作的人来说,这一点非常重要。
原因 3:文档编程助手
如果你从来没听过"RTFM"这个词,那可能因为没有在第一代开发者身边工作过。
向高级开发人员讨教是很有必要的,甚至去StackOverflow查找答案之前阅读文档。Kite Copilot让文档变得十分简单,其与编辑器同时运行,实时显示文档中光标掠过的任何对象/函数等。
结果
笔者使用Kite多年,它改进得也越来越好。其拥有超过1,700万美元的投资,不会轻易倒闭,而且它的工具是完全免费的。你只需要给编辑器下载Kite插件,或下载copilot(编码助手),就能安装插件。
秘密武器#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 中的静态键入
打开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。
秘密武器#3:用Sonarlint快速查找错误,编写更简单的函数
现在每个编辑器都有某种类型的错误检查或内置的"linter",可以用来查看代码,通常无需运行,并能预测可能存在的错误。这就是静态代码分析。
动态代码分析实际上尝试运行/编译代码的某些部分,以查看其是否正常工作,但它会自动在后台运行。它不是猜测,它事实上知道代码是否会出错,以及确切的错误是什么。
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是一个伟大的开端。
认知复杂性
这个话题十分有趣,笔者可以针对它写一篇完整的文章。
简单解释就是,有人创建了一个数学公式,这个公式可以对代码的阅读/理解难易程度进行评分。
它非常有用,还易于理解。每次SonarLint要求编码者"降低认知复杂性"时,它都会对编码者的不规范操作简单解释,比如"无法定义,嵌套异常"。
以上是关于Python中的三个秘密武器的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联-成都网站建设公司行业资讯频道!
当前题目:关于Python中的三个秘密武器-创新互联
本文URL:http://ybzwz.com/article/jppce.html