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

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

相关推荐
A__tao3 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
研究点啥好呢3 小时前
Github热门项目推荐 | 创建你的像素风格!
c++·python·node.js·github·开源软件
lly2024064 小时前
C 标准库 - `<stdio.h>`
开发语言
沫璃染墨4 小时前
C++ string 从入门到精通:构造、迭代器、容量接口全解析
c语言·开发语言·c++
jwn9994 小时前
Laravel6.x核心特性全解析
开发语言·php·laravel
迷藏4944 小时前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
功德+n4 小时前
Linux下安装与配置Docker完整详细步骤
linux·运维·服务器·开发语言·docker·centos
明日清晨4 小时前
python扫码登录dy
开发语言·python
我是唐青枫4 小时前
C#.NET gRPC 深入解析:Proto 定义、流式调用与服务间通信取舍
开发语言·c#·.net
JJay.4 小时前
Kotlin 高阶函数学习指南
android·开发语言·kotlin