Python 标准库中鲜为人知的宝藏 | Node.js 22.8.0 发布
off999 2024-09-29 16:10 18 浏览 0 评论
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 0
2 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
更多内容请查阅 :
x-cmd blog (daily) | [240907] Python 标准库中鲜为人知的宝藏 | Node.js 22.8.0 发布:编译缓存 API、覆盖率阈值等新特性
相关推荐
- python import 出现 ModuleNotFoundError 解决方法
-
错误的原因是你的Python环境没有正确安装库文件。本文以Scapy为例,给出详细方案:1.确认是否成功安装Scapy运行以下命令检查Scapy是否已安装:pip3list|gre...
- Github 7.4k star,一个强大的 Python 库-sh!
-
大家好,今天为大家分享一个强大的Python库-sh。Github地址:https://github.com/amoffat/shsh库是Python生态系统中一个专门用于执行系统命令的第三方...
- 学习编程第148天 python编程循环的嵌套使用
-
今天学习的是刘金玉老师零基础Python教程第32期,主要内容是python编程循环的嵌套使用。(一)一维数组及输出#一维数组list1=["110001","四川二流子...
- 2025-07-09:使数组元素互不相同所需的最少操作次数。用go语言,
-
2025-07-09:使数组元素互不相同所需的最少操作次数。用go语言,给定一个整数数组nums和一个整数k,对于数组中的每个元素,你最多可以对其进行一次操作:将一个在区间[-k,k]内的...
- python数据分析numpy基础之max求数组最大值
-
1python数据分析numpy基础之max求数组最大值python的numpy库的max()函数,用于计算沿指定轴(一个轴或多个轴)的最大值。用法numpy.max(a,axis=None,...
- 加快Python算法的四个方法(四)Dask
-
CDA数据分析师出品相信大家在做一些算法经常会被庞大的数据量所造成的超多计算量需要的时间而折磨的痛苦不已,接下来我们围绕四个方法来帮助大家加快一下Python的计算时间,减少大家在算法上的等待时间。...
- 六十六、Leetcode数组系列(中篇)(leetcode679)
-
@Author:Runsen@Date:2020/6/8人生最重要的不是所站的位置,而是内心所朝的方向。只要我在每篇博文中写得自己体会,修炼身心;在每天的不断重复学习中,耐住寂寞,练就真功,不畏艰难...
- Numpy中的ndarray是什么?('numpy.ndarray' object has no attribute 'append')
-
1.创建ndarray创建数组最简单的办法就是使用array函数。它接受一切序列型的对象(包括其他数组),然后产生一个新的含有传入数据的Numpy数组。np.array会尝试为新建的这个数组推断出一个...
- Python中的数据导入与查询(python怎样导入数据库)
-
适用场景:快速导入文本/Excel数据→Pandas读取大型数值数据→Numpy处理复杂二进制文件→h5py/scipy.io数据库交互→SQLAlchemy+Pandas一、数据...
- 2025-07-02:统计数组中的美丽分割。用go语言,给定一个整数数组
-
2025-07-02:统计数组中的美丽分割。用go语言,给定一个整数数组nums,我们要把它划分成三个连续且非空的子数组nums1、nums2、nums3,且这三个子数组按顺序拼接后还原为原数组...
- 2025-07-10:字符相同的最短子字符串Ⅰ。用go语言,给定一个长度
-
2025-07-10:字符相同的最短子字符串Ⅰ。用go语言,给定一个长度为n的二进制字符串s和一个允许执行的最大操作次数numOps。每次操作可以选择字符串中的任意一个位置i(0≤i...
- 2025-06-19:识别数组中的最大异常值。用go语言,你有一个长度为
-
2025-06-19:识别数组中的最大异常值。用go语言,你有一个长度为n的整数数组nums,其中恰好有n-2个元素属于“特殊数字”类别。剩下的两个元素中,一个等于所有这些特殊数字的总和,另...
- 2025-06-28:长度可被 K 整除的子数组的最大元素和。用go语言,给
-
2025-06-28:长度可被K整除的子数组的最大元素和。用go语言,给定一个整数数组nums和一个整数k,求nums中长度为k的倍数的非空子数组中,子数组和的最大值。返回该最大和...
- 在 Python 中如何向一个已排序的数组(列表) 中插入一个数呢
-
在Python中如何向一个已排序的数组(列表)中插入一个数呢?方法有很多种,关键在于原来数组是什么样的排序,用到啥排序方法效率高,就用哪种。我们来练习其中的几种插入方法,另外也掌握下遍历数组的...
- 2025-07-04:统计符合条件长度为 3 的子数组数目。用go语言,给定
-
2025-07-04:统计符合条件长度为3的子数组数目。用go语言,给定一个整数数组nums,请你计算有多少个长度恰好为3的连续子数组满足这样的条件:子数组的第一个元素与第三个元素的和,正好...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- python import 出现 ModuleNotFoundError 解决方法
- Github 7.4k star,一个强大的 Python 库-sh!
- 学习编程第148天 python编程循环的嵌套使用
- 2025-07-09:使数组元素互不相同所需的最少操作次数。用go语言,
- python数据分析numpy基础之max求数组最大值
- 加快Python算法的四个方法(四)Dask
- 六十六、Leetcode数组系列(中篇)(leetcode679)
- Numpy中的ndarray是什么?('numpy.ndarray' object has no attribute 'append')
- Python中的数据导入与查询(python怎样导入数据库)
- 2025-07-02:统计数组中的美丽分割。用go语言,给定一个整数数组
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python字典遍历 (54)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)