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

目录

关键字 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, keywordout = 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 = fhelp(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 sqlite3with 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 = 0def update_global():# 在函数内部声明 global_var 是全局变量global global_var# 修改全局变量的值global_var += 1print(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 = 5def inner_function():nonlocal outer_varouter_var = 15print("内部函数访问外部变量:", outer_var)inner_function()print("外部函数访问内部变量:", outer_var)outer_function()

 输出结果:

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

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

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

del

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

x = 10
print(x)  # 输出:10del xtry: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 = 0try:  # 尝试执行的代码  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 asynciodef fib(n):if n<600:n1 = n2 = 1for _ in range(2,n):n1,n2 = n1+n2,n1return n1t = n//2if n%2:return fib(t+1)**2 + fib(t)**2else:return fib(t+1)**2 - fib(t-1)**2def 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.rhkb.cn/news/242585.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

20240117在本地机器识别OCR法语电影的字幕效果PK

20240117在本地机器识别OCR法语电影的字幕效果PK 2024/1/17 11:18 1959 - Jirai Cracher Sur Vos Tombes [Gast, Vian].avi https://www.pianbar.net//drama/52892.html 1959[我唾弃你的坟墓]Jirai cracher sur vos tombes[BT下载/迅雷下载] magnet:?xturn:btih:7c9c99d9d048…

系统配置dns主从服务器

一、准备两台主机&#xff0c;区分主从 二、完全区域传送 1、主DNS服务器配置 #安装相关的包 [rootoula1 ~]# yum install bind -y#关闭防火墙 [rootoula1 ~]# systemctl stop firewalld [rootoula1 ~]# setenforce 0#修改配置主文件 [rootoula1 ~]# vim /etc/named.conf opt…

如何快速打开github

作为一个资深码农&#xff0c;怎么能不熟悉全球最大的同性交友社区——github呢&#xff0c;但头疼的是github有时能打开&#xff0c;有时打不开&#xff0c;这是怎么回事&#xff1f; 其实问题出在github.com解析DNS上&#xff0c;并不是需要FQ。下面提供一个方法&#xff0c;…

Baumer工业相机堡盟工业相机如何通过NEOAPI SDK使用相机日志跟踪功能(C#)

Baumer工业相机堡盟工业相机如何通过NEOAPI SDK使用相机日志跟踪功能&#xff08;C#&#xff09; Baumer工业相机Baumer工业相机NEOAPI SDK和短曝光功能的技术背景Baumer工业相机通过NEOAPI SDK使用相机日志跟踪功能1.引用合适的类文件2.通过NEOAPI SDK使用相机日志跟踪功能3.通…

C#,入门教程(30)——扎好程序的笼子,错误处理 try catch

上一篇&#xff1a; C#&#xff0c;入门教程(29)——修饰词静态&#xff08;static&#xff09;的用法详解https://blog.csdn.net/beijinghorn/article/details/124683349 程序员语录&#xff1a;凡程序必有错&#xff0c;凡有错未必改&#xff01; 程序出错的原因千千万&…

Centos 8 安装 Elasticsearch

简介&#xff1a;CentOS 8是一个基于Red Hat Enterprise Linux&#xff08;RHEL&#xff09;源代码构建的开源操作系统。它是一款稳定、可靠、安全的服务器操作系统&#xff0c;适合用于企业级应用和服务的部署。CentOS 8采用了最新的Linux内核和软件包管理系统&#xff0c;提供…

ThinkPad T14/T15/P14s/P15s gen2电脑原厂Win10系统镜像 恢复笔记本出厂时预装自带OEM系统

lenovo联想原装出厂Windows10系统&#xff0c;适用型号&#xff1a; ThinkPad T14 Gen 2&#xff0c;ThinPad T15 Gen 2&#xff0c;ThinkPad P14s Gen 2&#xff0c;ThinkPad P15s Gen 2 &#xff08;20W1,20W5,20VY,20W7,20W0,20W4,20VX,20W6&#xff09; 链接&#xff1…

Django从入门到精通(二)

目录 三、视图 3.1、文件or文件夹 3.2、相对和绝对导入urls 3.3、视图参数requests 3.4、返回值 3.5、响应头 3.6、FBV和CBV FBV 四、静态资源 4.1、静态文件 4.2、媒体文件 五、模板 5.1、寻找html模板 5.2、模板处理的本质 5.3、常见模板语法 5.4、内置模板函…

day25 组合总和Ⅲ 电话号码的字母组合

题目1&#xff1a;216 组合总和Ⅲ 题目链接&#xff1a;216 组合总和Ⅲ 题意 找出相加之和为n的k个数的组合 数字只可使用1~9之间的数&#xff08;包括 1 9&#xff09;且每个数字只能使用1遍 题目中有两个限制条件&#xff1a;1&#xff09;k个数 2&#xff09;k个…

C#使用DateTime.Now静态属性动态获得系统当前日期和时间

目录 一、实例 1.源码 2.生成效果 二、相关知识点 1.Thread类 &#xff08;1&#xff09;Thread.Sleep()方法 &#xff08;2&#xff09;Thread(ThreadStart) &#xff08;3&#xff09;IsBackground &#xff08;4&#xff09;Invoke( &#xff09; 2.CreateGrap…

༺༽༾ཊ—Unity之-01-单例模式—ཏ༿༼༻

在游戏开发过程中&#xff0c;我们会创建各种各样的类&#xff0c;再用new生成实例&#xff0c;有些时候我们需要这个类在整个游戏中是唯一出现的&#xff0c;比如一些管理器比如声音管理器等&#xff0c;没必要创建很多实例&#xff0c;就算有很多模块需要各种声音功能&#x…

为什么国产操作系统是基于linux研发的呢?

为什么国产操作系统是基于linux研发的呢&#xff1f; 在开始前我有一些资料&#xff0c;是我根据网友给的问题精心整理了一份「linux的资料从专业入门到高级教程」&#xff0c; 点个关注在评论区回复“888”之后私信回复“888”&#xff0c;全部无偿共享给大家&#xff01;&am…

数字IC笔试题——门控时钟与控制信号电平、与门门控、或门门控、上升沿门控、下降沿门控

门控时钟问题。 &#xff08;华为-2019-芯片-数字-34&#xff09; 从后端设计考虑&#xff0c;在必须使用门控时钟的时候&#xff0c;需要遵循一个原则&#xff1a;门控时钟的输出只能跟着时钟信号进行跳变&#xff0c;而不能跟着控制信号进行跳变&#xff0c;也就是说对于用N…

“GPC爬虫池有用吗?

作为光算科技的独有技术&#xff0c;在深入研究谷歌爬虫推出的一种吸引谷歌爬虫的手段 要知道GPC爬虫池是否有用&#xff0c;就要知道谷歌爬虫这一概念&#xff0c;谷歌作为一个搜索引擎&#xff0c;里面有成百上千亿个网站&#xff0c;对于里面的网站内容&#xff0c;自然不可…

【linux驱动】用户空间程序与内核模块交互-- IOCTL和Netlink

创建自定义的IOCTL&#xff08;输入/输出控制&#xff09;或Netlink命令以便用户空间程序与内核模块交互涉及几个步骤。这里将分别介绍这两种方法。 一、IOCTL 方法 1. 定义IOCTL命令 在内核模块中&#xff0c;需要使用宏定义你的IOCTL命令。通常情况下&#xff0c;IOCTL命令…

IDEA在重启springboot项目时没有自动重新build

IDEA在重启springboot项目时没有自动重新build 问题描述 当项目里面某些依赖或者插件更新了&#xff0c;target的class文件没有找到&#xff0c;导致不是我们需要的效果。 只能手动的清理target文件&#xff0c;麻烦得很 &#xff0c; 单体项目还好说&#xff0c;一次清理就…

pycharm import torch

目录 1 安装 2 conda环境配置 3 测试 开始学习Pytorch! 1 安装 我的电脑 Windows 11 Python 3.11 Anaconda3-2023.09-0-Windows-x86_64.exe cuda_11.8.0_522.06_windows.exe pytorch &#xff08;管理员命令行安装&#xff09; pycharm-community-2023.3.2.exe 2 c…

代码随想录 Leetcode150. 逆波兰表达式求值

题目&#xff1a; 代码(首刷看解析 2024年1月21日&#xff09;&#xff1a; class Solution { public:int evalRPN(vector<string>& tokens) {stack<long long> st; for (int i 0; i < tokens.size(); i) {if (tokens[i] "" || tokens[i] &qu…

css绘制下拉框头部三角(分实心/空心)

1:需求图: 手绘下拉框 带三角 2:网上查了一些例子,但都是实心的, 可参考,如图: (原链接: https://blog.csdn.net/qq_33463449/article/details/113375804) 3:简洁版的: a: 实心: <view class"angle"/>.angle{width:0;height:0;border-left: 10px solid t…

力扣每日一题---1547. 切棍子的最小成本

//当我们将棍子分段之后&#xff0c;我们是不是想到了怎么组合这些棍子 //并且这些棍子有一个性质就是只能与相邻的进行组合 //暴力搜索的话复杂度很高 //在思考暴力搜索的时候&#xff0c;我们发现一个规律 //比如棍子长度1 2 1 1 2 //那么与最后一个2组合的棍子有&#xff0c…