Python 库手册:keyword 关键字查询

keyword 模块是 Python 标准库中一个轻量级的内省工具,专门用于查询和判断 Python 的关键字(keywords)。

关键字是 Python 语言保留的标识符,具有特殊的语法意义,不能用作变量名、函数名或其他用户定义的标识符。例如:if、for、class、def 等。

该模块在语法学习、代码分析、编译器开发、静态检查工具等场景中非常有用。

常见应用场景:

(1)学习 Python 语法:查看当前版本的所有关键字列表。

(2)代码检查:判断某个字符串是否为关键字。

(3)工具开发:在代码高亮、自动补全或 IDE 插件中识别关键字。

(4)版本兼容性:不同 Python 版本关键字集合可能有差异,可通过该模块检测。

◆ ◆

核心概念

1、关键字(Keyword)

Python 语言保留字,不能作为普通标识符使用。

例如:True、False、None、import、lambda 等。

2、关键字集合

keyword.kwlist 提供了当前解释器版本的关键字列表。

随 Python 版本演进,关键字可能增减(如 match、case 在 3.10 引入)。

3、判断函数

keyword.iskeyword(s):判断字符串是否为关键字。

keyword.issoftkeyword(s):判断是否为"软关键字"(Python 3.9+)。

4、软关键字(Soft Keyword)

软关键字是在特定语境下才具有特殊含义的标识符。

例如,match 和 case 在 Python 3.10 的模式匹配(Pattern Matching)语法中是关键字,但在其他地方仍可作为变量名使用。

这与普通关键字不同,普通关键字在任何场景下都保留,不能作为标识符。

◆ ◆

应用举例

例 1:获取所有关键字

java 复制代码
import keyword
print(keyword.kwlist)

输出结果会随 Python 版本不同而略有差异(以下为 Python 3.11 示例):

javascript 复制代码
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield', 'match', 'case']

例 2:判断字符串是否为关键字

python 复制代码
import keyword
print(keyword.iskeyword("for"))     # Trueprint(keyword.iskeyword("hello"))   # False

例 3:判断软关键字(Python 3.9+)

python 复制代码
import keyword
print(keyword.issoftkeyword("match"))   # True (软关键字,用于模式匹配)print(keyword.issoftkeyword("hello"))   # False

例 4:避免关键字命名冲突

python 复制代码
import keyword
name = "class"if keyword.iskeyword(name):    print(f"'{name}' 是 Python 关键字,不能用作变量名!")

◆ ◆

常用函数与属性速览

keyword.kwlist

当前版本 Python 的所有关键字列表。

keyword.iskeyword(s)

判断字符串 s 是否为关键字。

返回:布尔值。

keyword.issoftkeyword(s)

判断字符串 s 是否为软关键字(soft keyword)。

返回:布尔值。

说明:软关键字在某些上下文中有特殊意义,但可以在其他场景下作为普通标识符使用。

📘 小结

keyword 模块提供了关键字集合与判断接口,是语法分析、代码检查和工具开发的重要辅助模块。

通过 kwlist、iskeyword() 和 issoftkeyword(),可快速获取关键字信息并避免命名冲突。

"点赞有美意,赞赏是鼓励"

相关推荐
java1234_小锋2 小时前
Scikit-learn Python机器学习 - 模型保存及加载
python·机器学习·scikit-learn
睿思达DBA_WGX2 小时前
使用 python-docx 库操作 word 文档(1):文件操作
开发语言·python·word
jackylzh4 小时前
深度学习中, WIN32为 Windows API 标识,匹配 Windows 系统,含 32/64 位
人工智能·python·深度学习
LateFrames5 小时前
用 【C# + Winform + MediaPipe】 实现人脸468点识别
python·c#·.net·mediapipe
人工干智能8 小时前
科普:Python 中,字典的“动态创建键”特性
开发语言·python
初听于你9 小时前
缓存技术揭秘
java·运维·服务器·开发语言·spring·缓存
长路归期无望11 小时前
C语言小白实现多功能计算器的艰难历程
c语言·开发语言·数据结构·笔记·学习·算法
开心-开心急了11 小时前
主窗口(QMainWindow)如何放入文本编辑器(QPlainTextEdit)等继承自QWidget的对象--(重构版)
python·ui·pyqt
是大强11 小时前
stm32摇杆adc数据分析
开发语言