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

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

相关推荐
molunnnn15 分钟前
第四章 Agent的几种经典范式
开发语言·python
洛_尘1 小时前
JAVA EE初阶 2: 多线程-初阶
java·开发语言
linuxxx1101 小时前
django测试缓存命令的解读
python·缓存·django
@卞2 小时前
C语言常见概念
c语言·开发语言
wjs20242 小时前
Eclipse 关闭项目详解
开发语言
沐知全栈开发2 小时前
《隐藏(Hide)》
开发语言
lkbhua莱克瓦242 小时前
Java基础——方法
java·开发语言·笔记·github·学习方法
catchadmin2 小时前
PHP 依赖管理器 Composer 2.9 发布
开发语言·php·composer
范纹杉想快点毕业3 小时前
《嵌入式开发硬核指南:91问一次讲透底层到架构》
java·开发语言·数据库·单片机·嵌入式硬件·mongodb