30天学会Python编程:4. Python运算符与表达式
off999 2025-07-07 22:18 45 浏览 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编程学习日志与技巧,敬请关注!
相关推荐
- 阿里云国际站ECS:阿里云ECS如何提高网站的访问速度?
-
TG:@yunlaoda360引言:速度即体验,速度即业务在当今数字化的世界中,网站的访问速度已成为决定用户体验、用户留存乃至业务转化率的关键因素。页面加载每延迟一秒,都可能导致用户流失和收入损失。对...
- 高流量大并发Linux TCP性能调优_linux 高并发网络编程
-
其实主要是手里面的跑openvpn服务器。因为并没有明文禁p2p(哎……想想那么多流量好像不跑点p2p也跑不完),所以造成有的时候如果有比较多人跑BT的话,会造成VPN速度急剧下降。本文所面对的情况为...
- 性能测试100集(12)性能指标资源使用率
-
在性能测试中,资源使用率是评估系统硬件效率的关键指标,主要包括以下四类:#性能测试##性能压测策略##软件测试#1.CPU使用率定义:CPU处理任务的时间占比,计算公式为1-空闲时间/总...
- Linux 服务器常见的性能调优_linux高性能服务端编程
-
一、Linux服务器性能调优第一步——先搞懂“看什么”很多人刚接触Linux性能调优时,总想着直接改配置,其实第一步该是“看清楚问题”。就像医生看病要先听诊,调优前得先知道服务器“哪里...
- Nginx性能优化实战:手把手教你提升10倍性能!
-
关注△mikechen△,十余年BAT架构经验倾囊相授!Nginx是大型架构而核心,下面我重点详解Nginx性能@mikechen文章来源:mikechen.cc1.worker_processe...
- 高并发场景下,Spring Cloud Gateway如何抗住百万QPS?
-
关注△mikechen△,十余年BAT架构经验倾囊相授!大家好,我是mikechen。高并发场景下网关作为流量的入口非常重要,下面我重点详解SpringCloudGateway如何抗住百万性能@m...
- Kubernetes 高并发处理实战(可落地案例 + 源码)
-
目标场景:对外提供HTTPAPI的微服务在短时间内收到大量请求(例如每秒数千至数万RPS),要求系统可弹性扩容、限流降级、缓存减压、稳定运行并能自动恢复。总体思路(多层防护):边缘层:云LB...
- 高并发场景下,Nginx如何扛住千万级请求?
-
Nginx是大型架构的必备中间件,下面我重点详解Nginx如何实现高并发@mikechen文章来源:mikechen.cc事件驱动模型Nginx采用事件驱动模型,这是Nginx高并发性能的基石。传统...
- Spring Boot+Vue全栈开发实战,中文版高清PDF资源
-
SpringBoot+Vue全栈开发实战,中文高清PDF资源,需要的可以私我:)SpringBoot致力于简化开发配置并为企业级开发提供一系列非业务性功能,而Vue则采用数据驱动视图的方式将程序...
- Docker-基础操作_docker基础实战教程二
-
一、镜像1、从仓库获取镜像搜索镜像:dockersearchimage_name搜索结果过滤:是否官方:dockersearch--filter="is-offical=true...
- 你有空吗?跟我一起搭个服务器好不好?
-
来人人都是产品经理【起点学院】,BAT实战派产品总监手把手系统带你学产品、学运营。昨天闲的没事的时候,随手翻了翻写过的文章,发现一个很严重的问题。就是大多数时间我都在滔滔不绝的讲理论,却很少有涉及动手...
- 部署你自己的 SaaS_saas如何部署
-
部署你自己的VPNOpenVPN——功能齐全的开源VPN解决方案。(DigitalOcean教程)dockovpn.io—无状态OpenVPNdockerized服务器,不需要持久存储。...
- Docker Compose_dockercompose安装
-
DockerCompose概述DockerCompose是一个用来定义和管理多容器应用的工具,通过一个docker-compose.yml文件,用YAML格式描述服务、网络、卷等内容,...
- 京东T7架构师推出的电子版SpringBoot,从构建小系统到架构大系统
-
前言:Java的各种开发框架发展了很多年,影响了一代又一代的程序员,现在无论是程序员,还是架构师,使用这些开发框架都面临着两方面的挑战。一方面是要快速开发出系统,这就要求使用的开发框架尽量简单,无论...
- Kubernetes (k8s) 入门学习指南_k8s kubeproxy
-
Kubernetes(k8s)入门学习指南一、什么是Kubernetes?为什么需要它?Kubernetes(k8s)是一个开源的容器编排系统,用于自动化部署、扩展和管理容器化应用程序。它...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
慕ke 前端工程师2024「完整」
-
失业程序员复习python笔记——条件与循环
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
- 最近发表
- 标签列表
-
- 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)
