30天学会Python编程:4. Python运算符与表达式
myzbx 2025-06-18 23:01 17 浏览
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编程学习日志与技巧,敬请关注!
相关推荐
- 零基础入门AI智能体:详细了解什么是变量类型、JSON结构、Markdown格式
-
当品牌跳出固有框架,以跨界联动、场景创新叩击年轻群体的兴趣点,一场关于如何在迭代中保持鲜活的探索正在展开,既藏着破圈的巧思,也映照着与新一代对话的密码。在创建AI智能体时,我们会调用插件或大模型,而在...
- C# 13模式匹配:递归模式与属性模式在真实代码中的性能影响分析
-
C#13对模式匹配的增强让复杂数据处理代码更简洁,但递归模式与属性模式的性能差异一直是开发者关注的焦点。在实际项目中,选择合适的模式不仅影响代码可读性,还可能导致执行效率的显著差异。本文结合真实测试...
- 零基础快速入门 VBA 系列 6 —— 常用对象(工作簿、工作表和区域)
-
上一节,我介绍了VBA内置函数以及如何自动打字和自动保存文件。这一节,我们来了解一下Excel常用对象。Excel常用对象Excel有很多对象,其中最常用也最重要的包括以下3个:1.Workbo...
- 不同生命数字的生肖龙!准到雷普!
-
属龙的人总在自信爆棚和自讨苦吃之间反复横跳?看完这届龙宝宝的日常我悟了。属龙的人好像天生自带矛盾体:领导力超强可人缘时好时坏,工作雷厉风行却总在爱情里翻车。关键年份的龙性格差异更大——76年龙靠谱但不...
- 仓颉编程语言基础-面向对象编程-属性(Properties)
-
属性是仓颉颉中一种强大的机制,它允许你封装对类(或接口interface、结构体struct、枚举enum、扩展extend)内部状态的访问。它看起来像一个普通的成员变量(字段),但在其背后,它通过...
- Python中class对象/属性/方法/继承/多态/魔法方法详解
-
一、基础入门:认识类和对象1.类和对象的概念在Python中,类(class)是一种抽象的概念,用于定义对象的属性和行为,而对象(也称为实例)则是类的具体表现。比如,“汽车”可以是一个类,它有...
- VBA基础入门:搞清楚对象、属性和方法就成功了一半
-
如果你刚接触VBA(VisualBasicforApplications),可能会被“对象”“属性”“方法”这些术语搞得一头雾水。但事实上,这三个概念是VBA编程的基石。只要理解它们之间的关系,...
- P.O类型文推荐|年度编推合集(一百九十五篇)
-
点击左上方关注获取更多精彩推文目录2019年度编推35篇(1V1)《悖论》作者:流苏.txt(1V1)《桂花蒸》作者:大姑娘浪.txt(1V1)《豪门浪女》作者:奚行.txt...
- Python参数传递内存大揭秘:可变对象 vs 不可变对象
-
90%的Python程序员不知道,函数参数传递中可变对象的修改竟会导致意想不到的副作用!一、参数传递的本质:对象引用传递在Python中,所有参数传递都是对象引用的传递。这意味着函数调用时传递的不是对...
- JS 开发者必看!TC39 2025 最新动向,这些新语法要火?
-
大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。TC39第...
- 2025 年值得尝试的 5 个被低估的 JavaScript 库
-
这些JavaScript库可能不会在社交媒体或HackerNews上流行起来,但它们会显著提高您的工作效率和代码质量。JavaScript不再只是框架。虽然React、Vue和Sv...
- Python自动化办公应用学习笔记30—函数的参数
-
一、函数的参数1.形参:o定义:在函数定义时,声明在函数名后面括号中的变量。o作用:它们是函数内部的占位符变量,用于接收函数被调用时传入的实际值。o生命周期:在函数被调用时创建,在函数执...
- 16种MBTI人格全解析|测完我沉默了三秒:原来我是这样的人?
-
MBTI性格测试火了这么久,你还不知道自己是哪一型?有人拿它当社交话题,有人拿它分析老板性格,还有人干脆当成择偶参考表。不废话,今天我一次性给你整理全部16种MBTI人格类型!看完你不仅能知道自己是谁...
- JS基础与高级应用: 性能优化
-
在现代Web开发中,性能优化已成为前端工程师必须掌握的核心技能之一。本文从URL输入到页面加载完成的全过程出发,深入分析了HTTP协议的演进、域名解析、代码层面性能优化以及编译与渲染的最佳实践。通过节...
- 爱思创CSP-J/S初赛模拟赛线上开赛!助力冲入2024年CSP-J/S复赛!
-
CSP-J/S组初赛模拟赛爱思创,专注信奥教育19年,2022年CSP-J/S组赛事指定考点,特邀NOIP教练,开启全真实CSP-J/S组线上初赛模拟大赛!一、比赛对象:2024年备考CSP-J/S初...
- 一周热门
- 最近发表
-
- 零基础入门AI智能体:详细了解什么是变量类型、JSON结构、Markdown格式
- C# 13模式匹配:递归模式与属性模式在真实代码中的性能影响分析
- 零基础快速入门 VBA 系列 6 —— 常用对象(工作簿、工作表和区域)
- 不同生命数字的生肖龙!准到雷普!
- 仓颉编程语言基础-面向对象编程-属性(Properties)
- Python中class对象/属性/方法/继承/多态/魔法方法详解
- VBA基础入门:搞清楚对象、属性和方法就成功了一半
- P.O类型文推荐|年度编推合集(一百九十五篇)
- Python参数传递内存大揭秘:可变对象 vs 不可变对象
- JS 开发者必看!TC39 2025 最新动向,这些新语法要火?
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)
- JS Loop For (32)