深度解析Python关键字:掌握核心语法的基石(新版本35+4)

news2025/4/19 15:15:54

目录

关键字 keyword

关键字列表

kwlist

softkwlist 

关键字分类 

数据类型

True、False

None

运算类型

and、or、not

in

is

模块导入

import

辅助关键字

from、as

上下文管理

with

占位语句

pass

流程控制

if、elif、else

for

while

break、continue

类和函数

class

def

lambda

return

yeild

变量相关

global

nonlocal

del

异常处理

try、except、finally

raise

assert

异步函数

async、await

软关键字

match、case、_

type

总结


关键字 keyword

Python关键字keyword,也被称为“保留字”,是有特殊功能的标识符,不允许开发者自定义。

本文将带你一起探索Python中的各类关键字及其应用场景,在python执行函数help("keywords")就能得到所有关键字的列表:

>>> help("keywords")
Here is a list of the Python keywords.  Enter any keyword to get more help.

False               class               from                or
None                continue            global              pass
True                def                 if                  raise
and                 del                 import              return
as                  elif                in                  try
assert              else                is                  while
async               except              lambda              with
await               finally             nonlocal            yield

当前python最新版本号为3.12,目前有35个关键字,比旧版本多了2个与异步编程相关的关键字;另外还多了四个所谓的“softkeyword”,导入keyword库,除了有kwlist还多了一个softkwlist。

>>> import keyword
>>> keyword.kwlist
['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']
>>> keyword.softkwlist
['_', 'case', 'match', 'type']
>>> len(keyword.kwlist)
35
>>> len(keyword.softkwlist)
4

keyword库还有两个判断函数,用法如下:

>>> keyword.iskeyword('async')
True
>>> keyword.iskeyword('match')
False
>>> keyword.issoftkeyword('_')
True
>>> keyword.issoftkeyword('await')
False

想获取所有关键字的英文帮助,可用以下代码实现:

import sys, keyword

out = sys.stdout #保存标准输出流

for i, kw in enumerate(keyword.kwlist+keyword.softkwlist, 1):
    fn = ("%02d" % i) + "." + kw + ".txt"
    with open(fn, 'w') as f:
    	sys.stdout = f
    	help(kw)
 
sys.stdout = out #恢复标准输出流
 
print("end")

关键字列表

kwlist

序号关键字功能
1True布尔类型,表示“真”,与 False 相反
2False布尔类型,表示“假”,与 True 相反
3None数据类型 - None Type,表示“无”,“空”
4and逻辑运算,与操作
5or逻辑运算,或操作
6not逻辑运算,非操作
7in成员运算
8is比较运算
9import模块导入,可以与 fromas 结合使用
10from可以与 import 结合使用;也可以与 yield 结合使用
11as可以与 import 结合使用;也可以与 with 结合使用
12with语句块,可以与 as 结合使用
13pass占位语句
14if条件语句,与 else、elif 结合使用
15elif与 if、else 结合使用
16else与 if、elif 结合使用;也可以用于异常或循环语句
17forfor 循环语句
18whilewhile 循环语句
19break中断循环语句的执行
20continue跳出本次循环,继续执行下一次循环
21class声明定义类
22def声明定义函数或方法
23return从函数返回计算结果
24yield从函数一次返回值,可以与 from 结合使用
25lambda定义匿名函数
26global定义全局变量
27nonlocal用于表示外部作用域的变量
28del删除变量或序列的值
29try捕获异常语句,与 except、finally、else 结合使用
30except捕获异常后的操作代码块,与 try、finally 结合使用
31finally异常语句中始终要执行 finally 包含的代码块
32assert断言,用于判断变量或者表示式的值是否为真
33raise异常抛出操作
34async声明异步函数
35await挂起异步函数

softkwlist 

序号关键字功能
36match匹配语句,与 case 结合使用,相于其它语言的switch语句
37case匹配语句,与 match 结合使用
38_下划线,与 case 结合使用,相当于其它语言的default语句
39type类型判断

关键字分类 

数据类型

True、False

布尔类型数据

>>> int(True)
1
>>> int(False)
0
>>> isinstance(True, type(False))
True

None

None类型数据

>>> isinstance(None, type(None))
True
>>> type(None)
<class 'NoneType'>

运算类型

and、or、not

逻辑运算符:与、或、非

in

成员运算符,用于判断对象是否包含于序列类型(如列表、元组、字符串)或其他可迭代对象(如集合、字典的键)中。

is

比较运算符,用于检查两个对象是否引用同一个内存地址,即判断它们是否是同一个对象实例。

A is B 相当于 id(A) == id(B)

模块导入

import

用于导入模块,import 模块名

也可以与from或as结合使用

from 模块名 import 具体模块方法、函数、属性等

import 模块名 as 模块别名

也可以使用 from ... import ... as ...

辅助关键字

from、as

这2个只能配合其他关键字一起使用,没有单独的功能,除了import语句中使用它俩外,还有:

with ... as ... 、 yield from ...

上下文管理

with

with语句块,实现上下文管理协议,确保在执行代码块前后自动调用初始化和清理操作。比如,在处理文件时,可以安全地打开和关闭文件,即使发生异常也能保证资源被释放,语句块结束会自动关闭已打开的文件对象。

with open('example.txt', 'r') as file:  
    content = file.read()  
    # 在这里处理文件内容  

# 文件已关闭

除了文件操作,还能在网络请求、 数据库连接、线程锁等场景中使用:

import socket  
  
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:  
    s.connect(("www.example.com", 80))  
    s.sendall(b"GET / HTTP/1.1\r\nHost: www.example.com\r\n\r\n")  
    response = s.recv(4096)  

# 连接已关闭
print(response)
import sqlite3

with sqlite3.connect('example.db') as conn:
    cursor = conn.cursor()
    # 执行 SQL 语句
    pass

# 数据库已关闭

with语句块还能嵌套使用:

   with A() as a:
       with B() as b:
             pass

也能写成等效的语句: with A() as a, B() as b: pass

占位语句

pass

什么都不做,临时占个位置,比如用在空类、空函数、空语句块等等。

流程控制

if、elif、else

条件语句,if 可以单独使用,还可以搭配elif和else使用,如 if-else, if-elif-else, if-elif-elif-else

else还能和循环语句或异常捕获语句一起使用,如 for-else, while-else, try-except-else

if和else还能用在类似三元操作符的结构中,如:

>>> x = 100
>>> 1 if x>0 else 0
1

for

for 循环语句

能通与 in 搭配使用 for ... in iterable:,也能与 else 结合使用。

while

while 循环语句

也能与 else 结合使用,while-else 和 for-else 一样在非break中断时循环结束后,继续执行else后的语句。

break、continue

循环中断和继续,区别是终止整个循环和退出单次循环。

注:if 和 for 搭配使用中列表、字典等的推导式中,如:

>>> [i for i in 'abcdef' if 'a'<i<'e']
['b', 'c', 'd']

类和函数

class

定义类

def

定义函数

lambda

定义匿名函数

return

函数终止并返回值。

yeild

函数终止并返回一个生成器

还可以与from连用,yeild from iterable 表示引用一个可迭代对像的值并返回生成器。

变量相关

global

声明全部变量

# 全局变量定义
global_var = 0

def update_global():
    # 在函数内部声明 global_var 是全局变量
    global global_var
    # 修改全局变量的值
    global_var += 1
    print(f"Inside function: {global_var}")

# 调用函数前查看全局变量的值
print("Before function call:", global_var)

# 调用函数
update_global()

# 函数调用后再次查看全局变量的值,会发现它已被修改
print("After function call:", global_var)
nonlocal

用于定义在嵌套函数中引用外部函数的变量。

def outer_function():
    outer_var = 5

    def inner_function():
        nonlocal outer_var
        outer_var = 15
        print("内部函数访问外部变量:", outer_var)

    inner_function()
    print("外部函数访问内部变量:", outer_var)

outer_function()

 输出结果:

内部函数访问外部变量: 15
外部函数访问内部变量: 15

上述的代码如果注释掉nonlocal outer_var这一行,输出结果变为:

内部函数访问外部变量: 15
外部函数访问内部变量: 5

del

用于删除变量、列表元素、字典元素或其他可变对象的引用。

x = 10
print(x)  # 输出:10

del x

try:
    print(x)
    # 此时尝试访问 x 将引发 NameError,因为 x 已被删除
except NameError as e:
    print(e)

输出:

10
name 'x' is not defined

异常处理

try、except、finally

捕获异常语句,也能与 else 一起使用,常用的结构有:

try-except;try-except-else;try-except-finally;try-except-else-finally

具体使用方法见以下实例中的注释:

x = 0

try:  
    # 尝试执行的代码  
    y = 1 / x  # 这里会引发一个ZeroDivisionError  
except ZeroDivisionError as e:  
    # 当发生ZeroDivisionError异常时执行的代码  
    print("发生了除以零的错误,错误信息为:", e)  
else:  
    # 如果try代码块中的代码没有引发任何异常,则执行此代码块  
    print("try代码块中的代码成功执行")  
finally:  
    # 不论是否发生异常,都会执行的代码  
    print("finally代码块中的代码总是会执行")

执行结果:

发生了除以零的错误,错误信息为: division by zero
finally代码块中的代码总是会执行

# 上述代码第一行改为 x = 1,则输出:
# try代码块中的代码成功执行
# finally代码块中的代码总是会执行

raise

异常抛出语句,可用于代码测试,但出错就会中断代码运行。

def validate_email(email):  
    if "@" not in email:  
        raise ValueError("无效的电子邮件地址!")  
    else:  
        print("电子邮件地址有效")  
  
validate_email("test@example")  # 输出: 电子邮件地址有效  
validate_email("test")  # 抛出ValueError: 无效的电子邮件地址!

也可以通过参数传递抛出系统定义的异常,以扩展异常捕获语句。

def handle_exception(e):
    # 对异常进行一些处理后,选择再次引发它
    print("Handling the exception...")
    raise e  # 再次引发原来的异常

try:
    x = 1/0
except ZeroDivisionError as e:
    handle_exception(e)
assert

断言语句,用于判断变量或者表示式的值是否为真;通常用于代码测试,且不会中断代码运行。

class Stack:
    def __init__(self):
        self.items = []

    def push(self, item):
        self.items.append(item)

    def pop(self):
        assert len(self.items) > 0, "Cannot pop from an empty stack."
        return self.items.pop()

stack = Stack()
stack.push('item1')

# 正常情况下的弹出操作
popped_item = stack.pop()

# 尝试从空栈中弹出元素,将触发AssertionError
try:
    popped_item_empty = stack.pop()
except AssertionError as e:
    print(f"Assertion error: {e}")

print("End")

输出:

Assertion error: Cannot pop from an empty stack.
End 

异步函数

async、await

python3.5新增的关键字,用于异步函数的定义声明和挂起执行。

import asyncio

def fib(n):
    if n<600:
        n1 = n2 = 1
        for _ in range(2,n):
            n1,n2 = n1+n2,n1
        return n1
    t = n//2
    if n%2:
        return fib(t+1)**2 + fib(t)**2
    else:
        return fib(t+1)**2 - fib(t-1)**2
 
def Fib(n):
    return fib(n)
 
async def asyncFib(n):
    res = Fib(n)
    print(res)
 
async def main():
    await asyncio.gather(*tasks)
 
if __name__ == "__main__":
    parms = [500, 2000, 10000]
    tasks = [asyncFib(p) for p in parms]
    loop = asyncio.run(main())

软关键字

match、case、_

python3.10新增的关键字,用于匹配语句,相当于其它语言中的分支结构switch-case。

之前的python版本中,一直由if...elif...[elif...]else来代替。

def process_data(data):
    match data:
        case 1:
            return "数据为1"
        case 2:
            return "数据为2"
        case 3:
            return "数据为3"
        case _:
            return "未知数据"

print(process_data(1))  # 输出:数据为1
print(process_data(2))  # 输出:数据为2
print(process_data(3))  # 输出:数据为3
print(process_data(4))  # 输出:未知数据
type

判断数据类型

>>> type(True)
<class 'bool'>
>>> type(False)
<class 'bool'>
>>> type(1.5)
<class 'float'>
>>> type(1+1j)
<class 'complex'>


总结

Python关键字是一些预定义的标识符,是编程语言内建的具有特殊含义的保留字,它们在语法结构、逻辑控制、错误处理等方面执行特定的操作。作为构成python语言语法结构的核心元素,不可用作变量名、类名或函数名等。理解并熟练运用这些关键字对于编写高质量、易于理解和维护的代码至关重要。Python3.12中共有35+4个关键字,其分类如下:


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1401845.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【C语言】动态内存函数介绍

目录 1.malloc和free 2.calloc 3.realloc 1.malloc和free C语言提供了一个动态内存开辟的函数malloc&#xff1a; void* malloc(size_t size); 这个函数向内存申请一块连续可用的空间&#xff0c;并返回指向这块空间的指针。 ✔如果开辟成功&#xff0c;则返回一个指向开…

数据分析实战:城市房价分析

流程图&#xff1a; 1.读数据表 首先&#xff0c;读取数据集。 CRIMZNINDUSCHASNOXRMAGEDISRADTAXPTRATIOBLSTATtarget0.00632182.3100.5386.57565.24.09129615.3396.94.98240.0273107.0700.4696.42178.94.9671224217.8396.99.1421.60.0272907.0700.4697.18561.14.9671224217…

Python-import hook机制原理与使用

背景 钩子函数&#xff08;hook function&#xff09;&#xff0c;可以理解是一个挂钩&#xff0c;作用是有需要的时候挂一个东西上去。具体的解释是&#xff1a;钩子函数是把我们自己实现的hook函数在某一时刻挂接到目标挂载点上。 在 Python 众多特性中&#xff0c;有一个特…

【设计模式】代理模式的实现方式与使用场景

1. 概述 代理模式是一种结构型设计模式&#xff0c;它通过创建一个代理对象来控制对另一个对象的访问&#xff0c;代理对象在客户端和目标对象之间充当了中介的角色&#xff0c;客户端不再直接访问目标对象&#xff0c;而是通过代理对象间接访问目标对象。 那在中间加一层代理…

大模型学习与实践笔记(十一)

一、使用OpenCompass 对模型进行测评 1.环境安装&#xff1a; git clone https://github.com/open-compass/opencompass cd opencompass pip install -e . 当github超时无法访问时&#xff0c;可以在原命令基础上加上地址&#xff1a; https://mirror.ghproxy.com git clon…

UG制图-创建图纸的多种方法

1、2D&#xff1a;创建独立2D图纸&#xff0c;不引用任何3D模型 在UG软件中选择新建&#xff0c;或者快捷键ctrl N&#xff0c;进入新建命令&#xff0c;然后点击图纸&#xff0c;在关系中选择独立的部件&#xff0c;就创建了一个独立的图纸&#xff0c;我们可以在装配中添加…

java eazyexcel 实现excel的动态多级联动下拉列表(1)使用名称管理器+INDIRECT函数

原理 将数据源放到一个新建的隐藏的sheet中将选项的子选项的对应字典设置到名称管理器中&#xff08;名称是当前选项的内容&#xff0c;值是他对应的子菜单的单元格范围&#xff0c;在1里面的sheet中&#xff09;子菜单的数据根据INDIRECT函数去左边那个单元格获取内容&#x…

KMP 算法详解(C++ Version)

KMP 算法详解&#xff08;C Version&#xff09; 简述字符串匹配问题Brute-Force 算法Brute-Force 算法的改进思路跳过不可能成功的字符串比较next 数组利用 next 数组进行匹配快速求 next 数组 简述 KMP 算法是一种字符串匹配算法&#xff0c;可以在 O(nm) 的时间复杂度内实现…

ZYNQ程序固化

文章目录 一、简介二、固化操作2.1 生成固化文件2.2 固化到SD卡2.3 固化到Flash 参考 将程序存储在非易失性存储器中&#xff0c;在上电或者复位时让程序自动加载运行。 这个过程需要启动引导程序( Boot Loader)参与&#xff0c;Boot Loader会加载FPGA配置文件&#xff0c;以及…

读元宇宙改变一切笔记12_元宇宙+

1. 元宇宙的价值 1.1. 元宇宙的价值&#xff0c;将“超过”物理世界 1.2. 移动互联网时代不是突然降临的 1.2.1. 我们可以确定一项特定的技术是何时被创造、测试或部署的&#xff0c;但不能确定一个时代何时开始或何时结束 1.2.2. 转型是一个迭代的过程&#xff0c;在这个过…

web架构师编辑器内容-完成属性设置的优化

对于业务组件来说&#xff0c;其属性是有很多的&#xff0c;如果把所有属性都平铺在页面上&#xff0c;就会非常长&#xff0c;而且想要更改其中的某些属性&#xff0c;可能需要向下滚动很久才能找到&#xff0c;对于UI的交互不是很友好&#xff0c;需要对属性的不同特性进行分…

彩色图像处理之彩色图像直方图处理的python实现——数字图像处理

彩色图像的直方图处理是一种重要的图像处理技术&#xff0c;用于改善图像的视觉效果&#xff0c;增强图像的对比度&#xff0c;或为后续的图像处理任务&#xff08;如图像分割、特征提取&#xff09;做准备。彩色图像通常由红色&#xff08;R&#xff09;、绿色&#xff08;G&a…

2023年12月 Scratch 图形化(一级)真题解析#中国电子学会#全国青少年软件编程等级考试

Scratch图形化等级考试(1~4级)全部真题・点这里 一、单选题(共25题,每题2分,共50分) 第1题 观察下列每个圆形中的四个数,找出规律,在括号里填上适当的数?( ) A:9 B:17 C:21 D:5 答案:C 左上角的数=下面两个数的和+右上角的数

【UEFI基础】EDK网络框架(UDP4)

UDP4 UDP4协议说明 UDP的全称是User Datagram Protocol&#xff0c;它不提供复杂的控制机制&#xff0c;仅利用IP提供面向无连接的通信服务。它将上层应用程序发来的数据在收到的那一刻&#xff0c;立即按照原样发送到网络。 UDP报文格式&#xff1a; 各个参数说明如下&…

Tomcat Notes: Web Security

This is a personal study notes of Apache Tomcat. Below are main reference material. - YouTube Apache Tomcat Full Tutorial&#xff0c;owed by Alpha Brains Courses. https://www.youtube.com/watch?vrElJIPRw5iM&t801s 1、Overview2、Two Levels Of Web Securi…

跨部门算法迭代需求,从提出到上线的全流程实践

文章目录 引言需求评审技术方案评审模块开发系统联调QA测试产品验收经验教训 引言 最近工作中有一个算法迭代的需求&#xff0c;我在其中作为技术侧负责人&#xff08;技术主R&#xff09;推动需求完成上线。 需求涉及多个部门&#xff0c;前后耗时接近1个月。 我第一次在这…

transdata笔记:手机数据处理

1 mobile_stay_duration 每个停留点白天和夜间的持续时间 transbigdata.mobile_stay_duration(staydata, col[stime, etime], start_hour8, end_hour20) 1.1 主要参数 staydata停留数据&#xff08;每一行是一条数据&#xff09;col 列名&#xff0c;顺序为[‘starttime’,…

Istio

1、Istio介绍 Istio 是由 Google、IBM 和 Lyft 开源的微服务管理、保护和监控框架。 官网&#xff1a;https://istio.io/latest/zh/ 官方文档&#xff1a;https://istio.io/docs/ 中文官方文档&#xff1a;https://istio.io/zh/docs Github地址&#xff1a;https://github.com…

System.Data.SqlClient.SqlException:“在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误

目录 背景: 过程: SQL Express的认识: 背景: 正在运行程序的时候&#xff0c;我遇到一个错误提示&#xff0c;错误信息如下&#xff0c;当我将错误信息仔细阅读了一番&#xff0c;信息提示的很明显&#xff0c;错误出现的来源就是连接数据库代码这块string connStr "s…

编写servlet

编写servlet 上述代码中的HTML页面将雇员ID发送给servlet。要创建servlet读取客户机发送的雇员ID并检索雇员的详细信息,需要执行以下步骤: 在“项目”选项卡中右击“Employee”节点,然后选择“新建”→Servlet。将显示“新建Servlet”对话框。在“类名”文本框中输入Employ…