30天学会Python编程:4. Python运算符与表达式
off999 2025-07-07 22:18 52 浏览 0 评论
4.1 运算符概述
4.1.1 运算符分类
Python运算符可分为以下几大类:
4.1.2 运算符优先级
表4-1 Python运算符优先级(从高到低)
运算符 | 描述 | 示例 |
** | 指数 | 2**3 → 8 |
~ + - | 按位取反/正负号 | ~5, +x, -y |
* / // % | 乘/除/整除/取模 | 10//3 → 3 |
+ - | 加/减 | 3+5 → 8 |
<< >> | 位移 | 4<<1 → 8 |
& | 按位与 | 5&3 → 1 |
^ | 按位异或 | 5^3 → 6 |
| | 按位或 | 5|3 → 7 |
< <= > >= | 比较运算 | 3<5 → True |
== != | 等于/不等于 | 3==3 → True |
is, is not | 身份运算 | x is None |
in, not in | 成员运算 | 2 in [1,2,3] |
not | 逻辑非 | not True → False |
and | 逻辑与 | True and False → False |
or | 逻辑或 | True or False → True |
4.2 算术运算符
4.2.1 基本算术运算
a, b = 10, 3
print(a + b) # 加法 13
print(a - b) # 减法 7
print(a * b) # 乘法 30
print(a / b) # 除法 3.333...
print(a // b) # 整除 3
print(a % b) # 取模 1
print(a ** b) # 指数 1000
4.2.2 增强算术运算
x = 5
x += 2 # 等价于 x = x + 2
x **= 3 # 等价于 x = x ** 3
print(x) # 343
4.2.3 特殊算术行为
# 除法总是返回浮点数
print(10 / 2) # 5.0
# 整数除法向下取整
print(-7 // 2) # -4
# 复数运算
c = 3 + 4j
print(c * 2) # (6+8j)
4.3 比较运算符
4.3.1 基本比较运算
a, b = 5, 7
print(a == b) # False
print(a != b) # True
print(a < b) # True
print(a >= b) # False
4.3.2 链式比较
x = 5
print(1 < x < 10) # True (等价于 1 < x and x < 10)
# 支持多个比较
print(1 < x <= 5 < 10) # True
4.3.3 特殊比较情况
# 浮点数比较
print(0.1 + 0.2 == 0.3) # False (精度问题)
print(abs((0.1 + 0.2) - 0.3) < 1e-10) # 正确比较方式
# 不同类型比较
print(10 == 10.0) # True (值相等)
print(10 is 10.0) # False (不是同一对象)
4.4 逻辑运算符
4.4.1 基本逻辑运算
x, y = True, False
print(x and y) # False
print(x or y) # True
print(not x) # False
4.4.2 短路求值特性
def check():
print("check()被调用")
return True
False and check() # check()不会被调用
True or check() # check()不会被调用
4.4.3 实际应用技巧
# 默认值设置
name = user_input or "匿名用户"
# 安全访问字典
value = my_dict.get("key") or default_value
# 条件执行
is_admin and admin_only_function()
4.5 位运算符
4.5.1 基本位运算
a, b = 0b1010, 0b1100 # 10, 12
print(bin(a & b)) # 按位与 0b1000 (8)
print(bin(a | b)) # 按位或 0b1110 (14)
print(bin(a ^ b)) # 按位异或 0b0110 (6)
print(bin(~a)) # 按位取反 -0b1011 (-11)
print(bin(a << 2)) # 左移 0b101000 (40)
print(bin(b >> 1)) # 右移 0b0110 (6)
4.5.2 位运算应用
# 快速乘除2的幂次
print(5 << 1) # 10 (5*2)
print(20 >> 2) # 5 (20/4)
# 判断奇偶
num = 7
is_odd = num & 1 # 1为奇,0为偶
# 交换两个数
a, b = 3, 4
a ^= b
b ^= a
a ^= b
print(a, b) # 4, 3
4.6 成员与身份运算符
4.6.1 成员运算符(in)
lst = [1, 2, 3]
dct = {"a": 1, "b": 2}
print(2 in lst) # True
print(4 not in lst) # True
print("a" in dct) # True (检查键)
print(1 in dct) # False
4.6.2 身份运算符(is)
x = [1, 2]
y = [1, 2]
z = x
print(x == y) # True (值相等)
print(x is y) # False (不同对象)
print(x is z) # True (同一对象)
# 小整数缓存
a = 256
b = 256
print(a is b) # True (Python缓存小整数)
c = 257
d = 257
print(c is d) # False (大整数不缓存)
4.7 海象运算符(:=)
4.7.1 基本用法
Python 3.8+引入的赋值表达式运算符:
# 传统写法
n = len("hello")
if n > 3:
print(n)
# 使用海象运算符
if (n := len("hello")) > 3:
print(n)
4.7.2 实用场景
# 循环中读取并判断
while (line := input()) != "quit":
print(f"输入: {line}")
# 列表推导式
numbers = [1, 2, 3, 4, 5]
squares = [y for x in numbers if (y := x**2) > 10]
4.8 运算符重载
4.8.1 类中运算符重载
class Vector:
def __init__(self, x, y):
self.x = x
self.y = y
def __add__(self, other):
return Vector(self.x + other.x, self.y + other.y)
def __str__(self):
return f"Vector({self.x}, {self.y})"
v1 = Vector(2, 3)
v2 = Vector(1, 4)
print(v1 + v2) # Vector(3, 7)
4.8.2 可重载运算符列表
表4-2 常用运算符重载方法
运算符 | 方法名 | 说明 |
+ | __add__ | 加法 |
- | __sub__ | 减法 |
* | __mul__ | 乘法 |
/ | __truediv__ | 真除法 |
// | __floordiv__ | 整除 |
% | __mod__ | 取模 |
** | __pow__ | 幂运算 |
<< | __lshift__ | 左移 |
>> | __rshift__ | 右移 |
& | __and__ | 按位与 |
| | __or__ | 按位或 |
^ | __xor__ | 按位异或 |
< | __lt__ | 小于 |
== | __eq__ | 等于 |
4.9 综合应用
案例1:简易计算器
def calculator():
"""支持加减乘除和指数的计算器"""
while True:
try:
expr = input("请输入表达式(或q退出): ").strip()
if expr.lower() == 'q':
break
# 使用eval实现简单计算(生产环境应使用更安全的方式)
result = eval(expr)
print(f"结果: {result:.2f}" if isinstance(result, float) else f"结果: {result}")
except (SyntaxError, NameError):
print("错误:无效表达式")
except ZeroDivisionError:
print("错误:不能除以零")
except Exception as e:
print(f"错误:{e}")
if __name__ == "__main__":
calculator()
案例2:权限控制系统
# 使用位运算管理权限
READ = 0b0001 # 1
WRITE = 0b0010 # 2
EXECUTE = 0b0100 # 4
ADMIN = 0b1000 # 8
class User:
def __init__(self, name, permissions=0):
self.name = name
self.permissions = permissions
def add_permission(self, perm):
self.permissions |= perm
def remove_permission(self, perm):
self.permissions &= ~perm
def has_permission(self, perm):
return self.permissions & perm == perm
def __str__(self):
perms = []
if self.has_permission(READ): perms.append("READ")
if self.has_permission(WRITE): perms.append("WRITE")
if self.has_permission(EXECUTE): perms.append("EXECUTE")
if self.has_permission(ADMIN): perms.append("ADMIN")
return f"{self.name} 权限: {', '.join(perms) or '无'}"
# 使用示例
user = User("Alice")
user.add_permission(READ | WRITE)
print(user) # Alice 权限: READ, WRITE
print("有写入权限:", user.has_permission(WRITE)) # True
print("有执行权限:", user.has_permission(EXECUTE)) # False
4.10 学习路线图
4.11 学习总结
- 核心要点:
- 掌握各类运算符的优先级和结合性
- 理解逻辑运算符的短路特性
- 熟练使用成员和身份运算符
- 了解位运算的实际应用场景
- 实践建议:
- 复杂表达式使用括号明确优先级
- 使用is比较单例对象(如None)
- 避免在复杂表达式中使用海象运算符
- 合理重载运算符增强类功能
- 进阶方向:
- 运算符的魔术方法实现
- 自定义异常处理运算错误
- 使用functools.total_ordering简化比较运算
- 元编程中的运算符控制
- 常见陷阱:
- 混淆==和is的用途
- 忽略浮点数比较的精度问题
- 误用可变对象的+=运算
- 忘记运算符优先级导致的逻辑错误
持续更新Python编程学习日志与技巧,敬请关注!
相关推荐
- win7安全模式进去也黑屏(win7安全模式黑屏只有鼠标能动)
-
分辨率设置超出范围或者显卡驱动有问题导致的。解决方法:1、开机按F8选择安全模式进入安全模式。2、在安全模式桌面用鼠标右键点我的电脑,属性,打开设备管理器,展开设备管理器,用鼠标右键选择显卡驱动卸载...
- win7激活程序(win7激活程序怎么用)
-
windows7的激活方法如下1、首先打开计算机,在计算机内找到暴风激活工具选项并使用鼠标右键点击,然后在弹出的选项栏内找到“以管理员身份运行”选项并使用鼠标点击。2、激活工具自动识别到win7版本,...
- 台式电脑联网怎么连接(台式电脑以太网怎么连接)
-
电脑连接家庭网络连接方法如下1.首先我们要检查自己的网络连接。检查网络连接的方法很简单,我们只需要把鼠标放到屏幕的上方,用右键点击一下桌面,点击“个性化”即可。 2.进入页面后我们点击左上方的主页。...
- 鸿蒙os系统(鸿蒙OS系统更新)
-
鸿蒙os是分布式模块化的一个系统!所谓的模块化就是它可以根据终端的不同,开发成不同的模块!但最底层都是一样的,都是鸿蒙!所以你会在电视,智能手表,手机等等产品上看到鸿蒙!鸿蒙是华为基于万物互联而打造的...
- 360手机助手极速版(360手机助手官方下载安装)
-
可以的,手机助手里面有很多功能,有手机加速悬浮球一、打开设定-关于设备-系统更新-更新。通过在线固件升级(FOTA)服务下载并安装固件更新。注:使用FOTA软件升级所需条件:1、稳定的WI-FI或...
- 幻影wifi手机版官网(幻影wifi2020官网版)
-
第一步、下载最新版“幻影Wifi破解软件”。 第二步、下载之后安装至手机。 第三步、安装成功后,就可以打开软件,之后该幻影Wifi破解软件会自动扫描接收到信号的WIFI,并且会显示几格信号...
- 怎么把c盘扩大(pe系统怎么把c盘扩大)
-
C盘的内存通常是指C盘的存储空间,而存储空间不能从别的盘直接增加,必须通过调整分区大小或者更换大容量硬盘来实现。具体操作可以通过以下两种方式之一:1.磁盘管理工具:在计算机的“控制面板”中找到“管理工...
- chrome 安卓下载(chrome安卓下载apk)
-
安卓手机可以先下载一个应用宝,然后在应用宝上下载一个谷歌地球,随后再下载一个ourplay,将之前下载的谷歌地球导入进ourplay就好了,谷歌地球就能使用了,我自己的手机就是这么操作的
- 最流畅的浏览器(浏览器流畅度排名)
-
我觉得QQ浏览器9.0就不错,我也是喜欢在浏览器上看视频,朋友给我推荐的这款。这款浏览器是以“快”著称的,体现在很多方面,上网速度快,平常看视频、玩游戏都是很流畅的,因为这款浏览器在系统的稳定性和流畅...
- sm总线控制器驱动下载(sm总线控制器是什么驱动程序)
-
SM总线控制器是主板控制芯片上的一个通信控制器.它主要是希望通过一条廉价并且功能强大的总线(由两条线组成),来控制主板上的设备并收集相应的信息。MBus为系统和电源管理这样的任务提供了一条控制总线,使...
- 固态硬盘选择mbr还是gpt(固态硬盘选择mbr还是guid)
-
固态硬盘用mbr。用mbr,除速度快之外,系统支持度更高。此外,微软对于gpt的支持还不是很好,win7以前的系统基本不支持gpt。主引导记录(MBR),也被称为主引导扇区,是计算机开机后访问硬盘时所...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
