当前位置: 首页 > 乐活 > 内容页

几个被淘汰的 Python 库,请不要再用! 微动态

2023-07-04 14:10:15 来源:哔哩哔哩

随着每个 Python 版本的发布,都会添加新模块,并引入新的更好的做事方式,虽然我们都习惯了使用好的旧 Python 库和某些做事方式,但现在也时候升级并利用新的和改进的模块及其特性了。


(相关资料图)

Pathlib 而不是 OS

pathlib 绝对是 Python 标准库中最近添加的更大的内容之一, 自 Python 以来,它一直是标准库的一部分,但很多人仍然使用 os 模块进行文件系统操作。

然而,pathlib 与旧的 相比具有许多优点 - 虽然 os 模块以原始字符串格式表示路径,但 pathlib 使用面向对象的样式,这使得它更具可读性和编写自然:

from pathlib import Pathimport # 老方式two_dirs_up = (((__file__)))# 新方式,可读性强two_dirs_up = Path(__file__).resolve().

路径被视为对象而不是字符串这一事实也使得可以创建一次对象,然后查找其属性或对其进行操作:

readme = Path("").resolve()print(f"Absolute path: {()}")# Absolute path: /home/martin/some/path/(f"File name: {}")# File name: (f"Path root: {}")# Path root: /print(f"Parent directory: {}")# Parent directory: /home/martin/some/pathprint(f"File extension: {}")# File extension: .mdprint(f"Is it absolute: {_absolute()}")# Is it absolute: True

我最喜欢 pathlib 的一个特性是可以使用 /(“除法”)运算符来连接路径:

# Operators:etc = Path('/etc')joined = etc / "" / "anacron"print(f"Exists? - {()}")# Exists? - True

重要的是要注意 pathlib 只是替代 而不是整个 os 模块, 它还包括 glob 模块的功能,因此如果你习惯于将 与 结合使用,那么你可以完全用pathlib替代它们。

在上面的片段中,我们展示了一些方便的路径操作和对象属性,但 pathlib 还包括你习惯于 的所有方法,例如:

print(f"Working directory: {()}")  # same as ()# Working directory: /home/martin/some/(() / "new_dir", exist_ok=True)  # same as ()print(Path("").resolve())  # same as ()# /home/martin/some/path/(())  # same as ()# /home/martin

有关 函数到 pathlib 中新函数的完整映射,请参阅 官方文档。

Secrets 而不是 OS

说到 os 模块,你应该停止使用的另一部分是 。相反,你应该使用自 Python 以来可用的新秘密模块:

# 老方式:import oslength = 64value = (length)print(f"Bytes: {value}")# Bytes: b'\xfa\xf3...\xf2\x1b\xf5\xb6'print(f"Hex: {()}")# Hex: faf3cc656370e31a938e7...33d9b023c3c24f1bf5# 新方式:import secretsvalue = _bytes(length)print(f"Bytes: {value}")# Bytes: b'U\xe9n\x87...\x85>\x04j:\xb0'value = _hex(length)print(f"Hex: {value}")# Hex: fb5dd85e7d73f7a08b8e3...4fd9f95beb08d77391

使用 实际上并不是这里的问题,引入secrets模块的原因是因为人们使用随机模块来生成密码等,即使随机模块不产生密码安全令牌。

根据文档,随机模块不应用于安全目的, 你应该使用 secrets 或 ,但 secrets 模块绝对更可取,因为它比较新,并且包含一些用于十六进制令牌的实用程序/便利方法以及 URL 安全令牌。

Zoneinfo 而不是 pytz

在 Python 之前,没有用于时区操作的内置库,所以每个人都在使用 pytz,但现在我们在标准库中有 zoneinfo,所以是时候切换了。

from datetime import datetimeimport pytz  # pip install pytzdt = datetime(2022, 6, 4)nyc = ("America/New_York")localized = (dt)print(f"Datetime: {localized}, Timezone: {()}, TZ Info: {}")# 新方式:from zoneinfo import ZoneInfonyc = ZoneInfo("America/New_York")localized = datetime(2022, 6, 4, tzinfo=nyc)print(f"Datetime: {localized}, Timezone: {()}, TZ Info: {}")# Datetime: 2022-06-04 00:00:00-04:00, Timezone: EDT, TZ Info: America/New_York

datetime 模块将所有时区操作委托给抽象基类 , 这个抽象基类需要一个具体的实现——在引入这个很可能来自 pytz 的模块之前。现在我们在标准库中有 zoneinfo,我们可以使用它。

然而,使用 zoneinfo 有一个警告——它假定系统上有可用的时区数据,UNIX 系统就是这种情况, 如果你的系统没有时区数据,那么你应该使用 tzdata 包,它是由 CPython 核心开发人员维护的第一方库,其中包含 IANA 时区数据库。

Dataclasses

Python 的一个重要补充是 dataclasses 包,它是 namedtuple 的替代品。

你可能想知道为什么需要替换 namedtuple?以下是你应该考虑切换到数据类的一些原因:

1、它可以是可变的

2、默认提供 repr、eq、init、hash 魔术方法,

3、允许指定默认值,

4、支持继承。此外,数据类还支持 frozen 和 slots(从 开始)属性以提供与命名元组的特征奇偶校验。

切换真的不应该太难,因为你只需要更改定义:

# 老方式:# from collections import namedtuplefrom typing import NamedTupleimport sysUser = NamedTuple("User", [("name", str), ("surname", str), ("password", bytes)])u = User("John", "Doe", b'tfeL+uD...\xd2')print(f"Size: {(u)}")# Size: 64# 新方式:from dataclasses import dataclass@dataclass()class User:   name: str   surname: str   password: bytesu = User("John", "Doe", b'tfeL+uD...\xd2')print(u)# User(name='John', surname='Doe', password=b'tfeL+uD...\xd2')print(f"Size: {(u)}, {(u) + (vars(u))}")# Size: 48, 152

在上面的代码中,我们还包含了大小比较,因为这是 namedtuple 和数据类之间的较大差异之一,如上所见,命名元组的大小要小得多,这是由于数据类使用 dict 来表示属性。

至于速度比较,除非你计划创建数百万个实例,否则属性的访问时间应该基本相同,或者不够重要:

import timeitsetup = '''from typing import NamedTupleUser = NamedTuple("User", [("name", str), ("surname", str), ("password", bytes)])u = User("John", "Doe", b'')'''print(f"Access speed: {min(('', setup=setup, number=10000000))}")# Access speed:  = '''from dataclasses import dataclass@dataclass(slots=True)class User:  name: str  surname: str  password: bytesu = User("John", "Doe", b'')'''print(f"Access speed: {min(('', setup=setup, number=10000000))}")# Access speed: 

如果以上内容说服了你打算切换到数据类,请尽快尝试吧

相反,如果你不想切换并且出于某种原因真的想使用命名元组,那么你至少应该使用键入模块而不是collections中的 NamedTuple:

# 不好方式的:from collections import namedtuplePoint = namedtuple("Point", ["x", "y"])# 更好的方式:from typing import NamedTupleclass Point(NamedTuple):    x: float    y: float

最后,如果你既不使用 namedtuple 也不使用数据类,你可能需要考虑直接使用 Pydantic。

Proper Logging 而不是 print

这不是标准库的最新添加,但值得使用 - 你应该使用正确的日志记录而不是打印语句, 如果你在本地调试问题,则可以使用 print,但对于任何无需用户干预即可运行的生产就绪程序,正确的日志记录是必须的。

特别是考虑到设置 Python 日志记录非常简单:

import (    filename='',    level=,    format='[%(asctime)s] {%(pathname)s:%(lineno)d} %(levelname)s - %(message)s',    datefmt='%H:%M:%S')("Some serious error occurred.")# [12:52:35] {<stdin>:1} ERROR - Some serious error ('Some warning.')# [12:52:35] {<stdin>:1} WARNING - Some warning.

与打印语句相比,上面的简单配置将为你提供卓越的调试体验, 最重要的是,你可以进一步自定义日志库以记录到不同的位置、更改日志级别、自动轮换日志等。

f-strings 而不是 format

Python 包含很多格式化字符串的方法,包括 C 样式格式化、f 字符串、模板字符串或 .format 函数, 不过,其中之一 - f-strings - 格式化的字符串文字 , 它们写起来更自然,可读性更强,并且是前面提到的选项中最快的。

因此,我认为没有必要争论或解释为什么要使用它们,然而,在某些情况下不能使用 f 字符串:

使用 % 格式的唯一原因是用于记录:

import loggingthings = "something happened..."logger = (__name__)("Message: %s", things)  # 评估内部记录器方法(f"Message: {things}")  # 立即评估

在上面的示例中,如果你使用 f 字符串,则表达式将立即计算,而使用 C 样式格式,替换将被推迟到实际需要时,这对于消息分组很重要,其中具有相同模板的所有消息都可以记录为一个, 这不适用于 f 字符串,因为模板在传递给记录器之前填充了数据。

此外,有些事情是 f-strings 根本无法做到的, 例如在运行时填充模板 - 即动态格式 - 这就是 f-strings 被称为文字字符串格式的原因:

# 动态设置模板及其参数def func(tpl: str, param1: str, param2: str) -> str:    return (param=param1, param2=param2)some_template = "First template: {param1}, {param2}"another_template = "Other template: {param1} and {param2}"print(func(some_template, "Hello", "World"))print(func(another_template, "Hello", "Python"))# 动态重用具有不同参数的相同模板.inputs = ["Hello", "World", "!"]template = "Here's some dynamic value: {value}"for value in inputs:    print((value=value))

最重要的是,尽可能使用 f 字符串,因为它们更具可读性和更高性能,但请注意,在某些情况下仍然首选和/或需要其他格式样式。

Tomllib 而不是 tomli

TOML 是一种广泛使用的配置格式,对于 Python 的工具和生态系统尤其重要,因为它用于 配置文件, 到目前为止,你必须使用外部库来管理 TOML 文件,但是从 Python 开始,将有一个名为 tomllib 的内置库,它基于 toml 包。

所以,一旦你切换到 Python ,你应该养成使用 import tomllib 而不是 import tomli 的习惯。少了一种需要担心的依赖!

# import tomli as tomllibimport tomllibwith open("", "rb") as f:    config = (f)    print(config)    # {'project': {'authors': [{'email': 'contact@',    #                           'name': 'Martin Heinz'}],    #              'dependencies': ['flask', 'requests'],    #              'description': 'Example Package',    #              'name': 'some-app',    #              'version': ''}}toml_string = """[project]name = "another-app"description = "Example Package"version = """""config = (toml_string)print(config)# {'project': {'name': 'another-app', 'description': 'Example Package', 'version': ''}}

Setuptools 而不是  distutils

最后一个更像是弃用通知:

由于 Distutils 已弃用,因此同样不鼓励使用任何来自 distutils 的函数或对象,Setuptools 旨在替换或弃用所有此类用途。

是时候告别 distutils 包并切换到 setuptools 了,setuptools 文档提供了有关如何替换 distutils 用法的指导, 除此之外,PEP 632 还为 setuptools 未涵盖的部分 distutils 提供迁移建议。

总结

每个新的 Python 版本都会带来新的特性,因此我建议你查看 Python 发行说明中的“新模块”、“不推荐使用的模块”和“已删除的模块”部分,这是了解 Python 标准重大变化的好方法 , 通过这种方式,你可以不断地将新功能和最佳实践整合到你的项目中。

标签:

潮流

更多

猜你喜欢

更多
中船系个股震荡走弱 中船科技直线跳水跌超7% 榆木脑袋_饭店榆木桌子翻新简单方法 如何简单翻新饭店的榆木桌子 PET铜箔概念股午后震荡回调 沪江材料跌超9%_环球微资讯 我想有个家歌词原唱(我想有个家歌词)|世界速看 焦点快看:推土机复盘【天使救助会】剧本杀复盘/解析/凶手是谁/真相答案 东方园林:积极参与“高标准高质量建设雄安新区” 语音直播行业遭 “关停潮”:涉超20个平台,主播数万佣金无法提现 焦点日报:女子等车睡得香 男子贼胆包天“贴面”做这事 组织约谈函询情况怎么写(组织约谈函询) 今日看点:2023 CSCRS 普瑞眼科专家共话屈光白内障手术发展 2023版30克熊猫银币现在市场价是多少(2023年07月04日) 广联达cad看图软件怎么用(广联达cad看图软件)_热门 奔跑的花棉袄 观热点:国家医保局就《谈判药品续约规则》及《非独家药品竞价规则》公开征求意见 郑州第一家24小时书店历经3次搬家后正式闭店 全球热头条丨气炸了!费莱尼赛后晒照,配上多个表情 天天观点:美丽阿尔山 美好新生活 华北高温“调休”后明起再发力 南方“焖蒸”加剧 A股迎来七月开门红 电脑鼠标没反应是怎么回事 台式电脑(电脑鼠标没反应是怎么回事) 世界新视野 环球微头条丨千亿规模城商行公开选聘行长 内容正在升级改造,请稍后再试!-全球资讯 当年的大地震级!7年前的今天 凯文-杜兰特加盟金州勇士! 天津供应雄安新区天然气主干管道投产-环球快讯 巴西总统解除卫生部长职务 为什么具体怎么回事|当前视点 《新石器时代》手游新服21服-星乌力公告 全球短讯!抓获153人 德阳公安“坚盾筑安”集中清查整治行动收官 ​痛心!长沙68岁老人舍己救3人后不幸溺亡 中企承担的麦加轻轨实现安全满负荷运营-全球热文 《只此江湖梦》原著小说是什么?《只此江湖梦》女主是谁? 《折腰》主要讲了什么?《折腰》原著结局怎么样? 当前热议!新一轮局地强降雨来袭 长江防总、长江委启动Ⅳ级应急响应 城建税和教育附加怎么算(城建税) “打折”“降费”!多家银行已行动 《狐妖小红娘》剧版什么时候播出?动画《狐妖小红娘》为什么停播? 伊力特:7月3日融资买入1153.46万元,融资融券余额2.89亿元 今日精选 《平凡之路》在哪个平台播出?《平凡之路》左娜和谁在一起了? 上市板块选择增多,上半年科创板、创业板 IPO 受理数量同比减少_前沿热点 注意啦!这些高速路段即将启用监控 《如影随心》讲的是什么?《如影随心》结局是怎么样的? 《了不起的长城》是什么节目?《了不起的长城》周深第几期加入的? 《密室大逃脱第五季》的嘉宾有谁?《密室大逃脱大神版》是什么节目? 中国中冶07月03日获沪股通增持212.74万股 《承欢记》是什么改编的?《承欢记》原著小说结局是什么? 微资讯!伊戈尔:目前已有用户侧储能项目在建设过程中 《你比星光美丽》原著小说叫什么?《你比星光美丽》韩廷是谁扮演的? 《雪鹰领主》的大祭司是谁?《雪鹰领主》讲的是什么? 65331部队历任团长_65331部队 当前观点 中国石化获浅层常压页岩气突破 今亮点 环球快资讯:惠同新材今日申购 发行价格5.8元/股 观察|瓦格纳大戏:打开的混乱之门,还是场不能成真的演出? 手机home键在哪_home键有什么用 陕西一管委会主任被前妻爆出几十年的黑料!小学学历出身的天花板_天天播报 世界视讯!不香了?又有两家基金股东拟清仓减持 城镇居民养老保险和灵活就业养老的区别(城镇居民) 欧洲主要股指普遍收跌 上交所向投行提多项要点 审慎核查IPO企业业绩下滑 东方甄选将首次启动app直播 科拓生物(300858):7月3日北向资金增持13.47万股_精彩看点 人人乐(002336):7月3日北向资金减持16.48万股 环球信息:朝微电子研发费率仅同行三分之一,股权代持纠纷悬而未决 每日速看!招商银行(03968.HK):7月3日南向资金减持39.75万股 渝湘高铁重庆至黔江段刘家山隧道贯通|天天短讯 3段奶粉口碑最好的前十名(美赞臣奶粉3段) 养父与养女解除收养关系可否通婚(养父与养女的爱) shittah下载_shittah 天天快资讯 春寒料峭是什么意思_春寒料峭的简单介绍_当前通讯 希望英语单词缩写(希望英语单词) wps求和快捷键ctrl加什么(wps求和快捷键) 美股三大指数集体转跌,截至目前,道指跌0.11%,标普500指数跌0.06%,纳指跌0.01% 讯息:镇江实验学校:快乐过暑假,安全不放假 京东叮咚(关于京东叮咚的基本详情介绍) oppo没有密码如何恢复出厂设置_oppo如何恢复出厂设置 全球最资讯 30+球员联赛参与进球榜:梅西居首,格子、萨拉赫、莱万在列 焦点精选 世界热点!广东河源市东源县发生3.7级地震 热门SUV:第三代哈弗H6!_今日热讯 信音电子:网上发行中签率为0.0260660134%-全球头条 光明日报报电子版_光明日报电子报|资讯推荐 国资委召开中央企业能源电力保供工作推进会 环球热议 堀北铃音_堀北 请查收!大学师兄师姐的暖心喊话-当前独家 出尘香是什么意思(出尘) 重返未来1999修勾和远旅对比解析攻略 海伦哲因信息披露违规被深圳证券交易所采取监管措施 半小时拿到调解书,当天取得房产证!府院联动为房产纠纷提速 奥普特(688686.SH):持续迭代产品和技术,加快产品线布局 航发控制股东户数下降3.08%,户均持股53.78万元 烟台市政协主席于永信:以要素双向流通推动城乡融合发展 2011年开学第一课主题是什么_2011年开学第一课 今日聚焦 汇中股份:公司与安富利签署战略合作协议 苹果se手机怎么录屏幕(IE11兼容模式怎么设置)|看点 消息!三安光电(600703.SH):重庆高永向控股股东三安电子增资100亿元 每日焦点!国内首个绿色算力超市正式上线 力鸿检验(01586.HK)7月3日收盘涨2.14%,主力资金净流入84.66万港元 河北辛集:创新引领高质量发展_环球短讯 中国工商银行股份有限公司福州闽都支行收到中国银保监会福建监管局的行政处罚决定-环球观点 缅甸国内物价再次飞涨,民众吃苦却又无可奈何|热文 当前热议!辽宁省公务员成绩查询 辽宁省公务员成绩查询时间) 腾势汽车6月份销量和5月基本相同,销量这就上不去了? 东京市中心发生爆炸 现场烟雾弥漫

时尚

  1. 青岛市气象台解除大雾黄色预警信号

    青岛市气象台解除大雾黄色预警信号

  2. 微型计算机基本原理与接口技术(微型计算机接口技术及应用)-天天热闻

    微型计算机基本原理与接口技术(微型计算机接口技术及应用)-天天热闻

  3. 世界今热点:崇左搭好就业留人“大平台”,“职”等你来

    世界今热点:崇左搭好就业留人“大平台”,“职”等你来

  4. 日本强推核污染水排海,中国大使馆阐述立场

    日本强推核污染水排海,中国大使馆阐述立场

  5. 全球看热讯:股市集合竞价的规则_股市集合竞价规则简介介绍

    全球看热讯:股市集合竞价的规则_股市集合竞价规则简介介绍

  6. 精进电动-UW(688280)7月4日10点9分触及涨停板

    精进电动-UW(688280)7月4日10点9分触及涨停板

  7. 苍井空漫画_苍井空在线观看完整版-全球视讯

    苍井空漫画_苍井空在线观看完整版-全球视讯

  8. 都体:热刺米兰国米罗马等队竞争辛戈,都灵要价1200万-1500万欧 天天关注

    都体:热刺米兰国米罗马等队竞争辛戈,都灵要价1200万-1500万欧 天天关注

  9. 天天百事通!2023年云海金属分析报告 主营有色金属的冶炼和压延加工业务

    天天百事通!2023年云海金属分析报告 主营有色金属的冶炼和压延加工业务

  10. 国庆中秋庆双节简笔画怎么画?_中秋节和国庆节的简笔画怎么画_环球看热讯

    国庆中秋庆双节简笔画怎么画?_中秋节和国庆节的简笔画怎么画_环球看热讯