Python学不会来打我(17)逻辑运算符的使用方法与使用场景
wptr33 2025-07-10 21:25 18 浏览
在Python编程中,逻辑运算符(Logical Operators) 是用于组合多个条件表达式的关键工具。它们可以将多个布尔表达式连接起来,形成更复杂的判断逻辑,并返回一个布尔值(True 或 False)。掌握逻辑运算符是编写分支结构、循环控制和数据筛选程序的基础。
本文将详细讲解 3种常见的逻辑运算符:and、or 和 not,并通过大量示例帮助你理解它们的使用方法、执行规则以及适用场景。
一、Python中的逻辑运算符概述
二、各逻辑运算符详解与使用场景
1. and 运算符
基本用法:
a = (5 > 3) and (10 < 20)
print(a) # 输出 True
只有当左右两个表达式都为 True 时,整体结果才是 True;否则为 False。
使用场景:
- 多重条件判断:
age = int(input("请输入你的年龄:"))
if age >= 18 and age <= 60:
print("你处于工作年龄段。")
- 登录验证(用户名和密码都正确):
username = input("请输入用户名:")
password = input("请输入密码:")
if username == "admin" and
password == "123456":
print("登录成功!")
else:
print("用户名或密码错误!")
- 数据过滤:
scores = {"Tom": 85, "Jerry": 92, "Lucy": 78}
for name, score in scores.items():
if score >= 80 and score <= 90:
print(f"{name} 的成绩在良好区间。")
短路特性:
and 具有短路求值特性:如果第一个条件为 False,后面的条件不再判断,直接返回 False。
x = 0
result = x != 0 and 10 / x > 1
# 不会报错,因为 x != 0 为 False
2. or 运算符
基本用法:
a = (5 > 10) or (10 < 20)
print(a) # 输出 True
只要有一个条件为 True,整体结果就是 True;只有当所有条件都为 False 时,结果才是 False。
使用场景:
- 多选一条件判断:
day = input("请输入星期几:")
if day == "周六" or day == "周日":
print("今天是休息日。")
else:
print("今天是工作日。")
- 设置默认值(避免空值问题):
user_input = input("请输入你的名字:")
name = user_input or "匿名用户"
print(f"欢迎回来,{name}")
- 权限判断:
role = input("请输入你的角色(user/admin/guest)")
if role == "admin" or role == "user":
print("你有访问权限。")
else:
print("你没有访问权限。")
短路特性:
or 同样具有短路求值特性:一旦发现某个条件为 True,就立即返回该值,后续不再判断。
a = None
b = a or "默认值"
print(b) # 输出 "默认值"
3. not 运算符
基本用法:
a = not (5 > 10)
print(a) # 输出 True
not 是一元运算符,对一个布尔值进行取反操作。
使用场景:
- 判断非条件:
logged_in = False
if not logged_in:
print("请先登录后再继续操作。")
- 数据排除:
fruits = ["apple", "banana", "cherry"]
exclude = "banana"
for fruit in fruits:
if not fruit == exclude:
print(fruit)
- 输入验证:
response = input("是否继续?(Y/N): ").strip().upper()
if not response.startswith("Y"):
print("操作已取消。")
三、逻辑运算符的优先级与结合性
Python中不同运算符有不同的执行顺序,了解优先级有助于避免错误。
示例:
result = True or False and not True
# 执行顺序:not True → False
# False and False → False
# True or False → True
print(result) # 输出 True
注意:合理使用括号可以提高代码可读性并避免歧义。
result = (True or False) and (not True)
print(result) # 输出 False
四、逻辑运算符在实际项目中的应用举例
场景1:注册系统验证信息完整性
username = input("请输入用户名:")
password = input("请输入密码:")
confirm_password = input("请再次确认密码")
if username and password and
password == confirm_password:
print("注册成功!")
else:
print("注册失败,请检查输入内容。")
场景2:商品购买资格判断
balance = float(input("请输入账户余额:"))
points = int(input("请输入积分数量:"))
if balance > 100 or points > 500:
print("您有资格参与限时折扣活动。")
else:
print("您的账户不符合参与条件。")
场景3:考试成绩等级判断优化版
score = int(input("请输入考试成绩:"))
if score >= 90:
grade = "A"
elif 80 <= score < 90:
grade = "B"
elif 70 <= score < 80:
grade = "C"
elif 60 <= score < 70:
grade = "D"
else:
grade = "F"
print(f"你的成绩等级为:{grade}")
五、注意事项与最佳实践
- 避免滥用逻辑运算符导致代码难以阅读:
- 条件判断尽量简洁明了,避免嵌套过深。
- 复杂条件建议拆分为多个变量或函数。
- 注意逻辑运算符的短路特性:
- 利用短路特性可以提升性能,但也要注意可能跳过的副作用代码。
- 使用 in 替代多个 == 判断:
- 当需要判断多个可能值时,更简洁高效。
day = input("请输入星期几:")
if day in ["周一", "周二", "周三"]:
print("本周工作日")
- 不要直接比较布尔值:直接使用变量本身即可,不需要写成 if condition == True:。
is_valid = check_input()
if is_valid: # 推荐写法
print("输入有效")
- 合理使用括号明确优先级:多条件判断时使用括号提升可读性。
if (age > 18) and (age < 60):
print("符合条件")
六、总结
逻辑运算符是Python中最基础也是最强大的工具之一。通过 and、or 和 not,我们可以构建出复杂而灵活的条件判断逻辑,广泛应用于用户输入验证、权限控制、数据筛选、流程控制等多个方面。
作为Python初学者,建议你在练习中多动手写代码,尝试不同的逻辑组合,理解它们的行为差异。随着学习的深入,你会发现逻辑运算符在实际开发中的强大作用。
希望本文能帮助你全面掌握Python中的逻辑运算符,并在今后的编程实践中灵活运用!
相关推荐
- MySQL进阶五之自动读写分离mysql-proxy
-
自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
-
引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...
- 一文由浅入深带你完全掌握MySQL的锁机制原理与应用
-
本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...
- 验证Mysql中联合索引的最左匹配原则
-
后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...
- MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
-
目录1.索引基础...
- 你会看 MySQL 的执行计划(EXPLAIN)吗?
-
SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...
- MySQL 从入门到精通(四)之索引结构
-
索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...
- mysql总结——面试中最常问到的知识点
-
mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...
- mysql总结——面试中最常问到的知识点(2)
-
首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...
- MySQL基础全知全解!超详细无废话!轻松上手~
-
本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...
- 深入剖析 MySQL 中的锁机制原理_mysql 锁详解
-
在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...
- Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析
-
引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...
- MySQL基础篇:DQL数据查询操作_mysql 查
-
一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...
- MySql:索引的基本使用_mysql索引的使用和原理
-
一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
redission YYDS spring boot redission 使用
-
SparkSQL——DataFrame的创建与使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)