当前位置: 首页 > news >正文

深度解析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个关键字,其分类如下:


相关文章:

  • kubeadm 安装k8s集群后,master节点notready问题解决方案
  • JavaEE中的监听器的作用和工作原理
  • Spring Boot3.2.2整合MyBatis Plus3.5.5
  • 在Nginx中配置实现动静分离
  • C++中的static(静态)
  • 分布式锁4 :数据库DB实现分布式锁的悲观锁和乐观锁,unique实现方式
  • Spring、Spring-MVC、Mybatis、Mybatis-generator整合核心配置文件记录
  • 如何发布自己的npm包
  • ​LeetCode解法汇总2182. 构造限制重复的字符串
  • 大数据技术原理及应用课实验4: NoSQL和关系数据库的操作比较
  • Java leetcode简单刷题记录3
  • 【Linux 内核源码分析】堆内存管理
  • Glass Scienttan
  • 题记(22)--计算表达式
  • Unity中实现捏脸系统
  • 【140天】尚学堂高淇Java300集视频精华笔记(86-87)
  • CAP 一致性协议及应用解析
  • java中的hashCode
  • JS基础篇--通过JS生成由字母与数字组合的随机字符串
  • js继承的实现方法
  • leetcode386. Lexicographical Numbers
  • leetcode388. Longest Absolute File Path
  • Redis在Web项目中的应用与实践
  • select2 取值 遍历 设置默认值
  • spring boot下thymeleaf全局静态变量配置
  • Stream流与Lambda表达式(三) 静态工厂类Collectors
  • Vim 折腾记
  • vue2.0开发聊天程序(四) 完整体验一次Vue开发(下)
  • 分享一份非常强势的Android面试题
  • 聊聊spring cloud的LoadBalancerAutoConfiguration
  • 面试题:给你个id,去拿到name,多叉树遍历
  • 使用阿里云发布分布式网站,开发时候应该注意什么?
  • 小程序 setData 学问多
  • 一个普通的 5 年iOS开发者的自我总结,以及5年开发经历和感想!
  • 译米田引理
  • 用 Swift 编写面向协议的视图
  • 阿里云API、SDK和CLI应用实践方案
  • ​第20课 在Android Native开发中加入新的C++类
  • #if #elif #endif
  • #if和#ifdef区别
  • $(function(){})与(function($){....})(jQuery)的区别
  • %3cscript放入php,跟bWAPP学WEB安全(PHP代码)--XSS跨站脚本攻击
  • (13)[Xamarin.Android] 不同分辨率下的图片使用概论
  • (DFS + 剪枝)【洛谷P1731】 [NOI1999] 生日蛋糕
  • (pytorch进阶之路)扩散概率模型
  • (Redis使用系列) Springboot 实现Redis 同数据源动态切换db 八
  • (编程语言界的丐帮 C#).NET MD5 HASH 哈希 加密 与JAVA 互通
  • (利用IDEA+Maven)定制属于自己的jar包
  • (六)vue-router+UI组件库
  • (四)库存超卖案例实战——优化redis分布式锁
  • (转)编辑寄语:因为爱心,所以美丽
  • .FileZilla的使用和主动模式被动模式介绍
  • .locked1、locked勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .net core 6 使用注解自动注入实例,无需构造注入 autowrite4net
  • .Net Core 中间件验签