目录
- Python 标准库中鲜为人知的宝藏
- 数据结构:超越列表和字典
- 上下文管理器:简化资源管理
- 精确计算:Decimal 和 Fractions
- 深入代码:反汇编模块 `dis`
- 统计分析:`statistics` 模块
- 自动化浏览器:`webbrowser` 模块
- 简化分发:`zipapp` 模块
- Node.js 22.8.0 发布:编译缓存 API、覆盖率阈值等新特性
- 一、全新 JS 编译缓存 API
- 二、`vm.createContext()` 新增选项
- 三、支持覆盖率阈值
Python 标准库中鲜为人知的宝藏
Python 标准库功能强大,但有些模块却鲜为人知。本文将介绍一些有趣且实用的模块,助你提升代码效率和功能 。
数据结构:超越列表和字典
除了常用的列表和字典,collections
模块提供了更强大的数据容器:
- Deque: 双端队列,高效地从两端插入和删除元素。
- Counter: 字典子类,用于计数。
- ChainMap: 无需复制数据,即可跨多个字典提供统一键值映射的元字典。
- 高级映射结构:
- OrderedDict: 维护键值对顺序的字典,例如处理特定安全机制的 HTTP 头值时。
- namedtuple: 创建具有命名字段的 tuple 子类的工厂函数,比
dict
更面向对象。 - defaultdict: 预先填充部分或全部值的字典,例如处理网页抓取中可能缺少的字段。
- UserDict、UserList 和 UserString:
dict
、list
和str
的包装器,用于进一步子类化。
上下文管理器:简化资源管理
with
关键字创建上下文管理器,自动清理词法作用域内的资源。例如,无需手动关闭文件:
with open("results.txt", "w") as out_f:out_f.write("...\n")...
contextlib
模块提供了处理上下文管理器的帮助程序,例如使用 @contextmanager
注解将自定义函数转换为可通过 with
语法使用的函数。
精确计算:Decimal 和 Fractions
浮点数计算可能产生奇怪的结果:
>>> 0.1 + 0.1 + 0.1 - 0.3
5.551115123125783e-17
decimal
模块通过运算符重载将十进制数表示为 Python 对象,并调整计算以获得正确结果:
>>> from decimal import *
>>> one_point_two = Decimal('1.2')
>>> two_point_two = Decimal('2.2')
>>> one_point_two + two_point_two
Decimal('3.4')
类似地,fractions
模块通过运算符重载将分数表示为 Python 对象:
>>> import fractions
>>> one_third = fractions.Fraction(numerator=1, denominator=3)
>>> 2 * one_third
Fraction(2, 3)
深入代码:反汇编模块 dis
dis
模块将 Python 代码反汇编为指令,用于调试或性能优化:
>>> import dis
>>> def add(a, b):
... return a+b
...
>>> dis.dis(add)1 0 RESUME 02 2 LOAD_FAST 0 (a)4 LOAD_FAST 1 (b)6 BINARY_OP 0 (+)10 RETURN_VALUE
统计分析:statistics
模块
statistics
模块提供了一套统计算法,适用于不需要 Pandas 或 Numpy 的简单应用,例如计算标准差、均值、线性回归、相关性、正态分布等。
自动化浏览器:webbrowser
模块
webbrowser
模块提供了一个简单的 API,用于从 Python 代码中打开网页浏览器:
>>> import webbrowser
>>> webbrowser.open_new('https://www.baidu.com')
True
简化分发:zipapp
模块
zipapp
模块提供 CLI 工具和 Python API,用于将 Python 代码打包成单个文件,简化分发过程,同时保持代 码的可移植性。
Python 标准库中隐藏着许多宝藏,掌握它们可以提升代码效率和功能。希望本文能激发你探索这些鲜为人知模块 的兴趣,并在实际项目中加以应用。
来源:
https://www.trickster.dev/post/lesser-known-parts-of-python-standard-library/
Node.js 22.8.0 发布:编译缓存 API、覆盖率阈值等新特性
Node.js 22.8.0 版本已发布,带来了一些令人兴奋的新特性和改进。
一、全新 JS 编译缓存 API
新版本引入 module.enableCompileCache()
API,用于启用模块加载后的磁盘代码缓存。之前只能通过 NODE_COMPILE_CACHE
环境变量启用,限制了工具和库作者对自身代码缓存的控制。
新 API 具有以下优势:
- 内置替代
v8-compile-cache
和v8-compile-cache-lib
包 - 性能更优
- 支持 ESM
// 启用编译缓存
module.enableCompileCache();// 之后加载的模块将被缓存
import { myModule } from './my-module.js';
二、vm.createContext()
新增选项
vm.createContext()
方法新增选项,允许创建具有可冻结 globalThis
的上下文。当使用 vm.constants.DONT_CONTEXTIFY
时,将创建一个不进行上下文化的上下文,适用于需要冻结上下文或加速全局访问的场景。
const vm = require('vm');// 创建具有可冻结 globalThis 的上下文
const context = vm.createContext({},{ contextExtensions: [vm.constants.DONT_CONTEXTIFY] }
);// 冻结上下文
Object.freeze(context);
三、支持覆盖率阈值
新版本支持在进程成功退出前要求代码覆盖率达到特定阈值。
启用 --experimental-test-coverage
标志后,可以使用以下选项设置阈值:
- 分支覆盖率:
--test-coverage-branches=<threshold>
- 函数覆盖率:
--test-coverage-functions=<threshold>
- 行覆盖率:
--test-coverage-lines=<threshold>
<threshold>
应为 0 到 100 之间的整数。
例如,要强制要求至少 80% 的行覆盖率和 60% 的分支覆盖率,可以运行:
$ node --experimental-test-coverage --test-coverage-lines=80 --test-coverage-branches=60 example.js
Node.js 22.8.0 版本带来了许多实用新特性和改进,包括编译缓存 API、测试覆盖率阈值支持等,提升了开发者体验和代码性能。
来源:
https://nodejs.org/en/blog/release/v22.8.0
更多内容请查阅 : blog-240907
关注微信官方公众号 : oh my x
获取开源软件和 x-cmd 最新用法