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(),可快速获取关键字信息并避免命名冲突。

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