Pandas知识点-逻辑运算Python 碎片关注共 1593字,需浏览 4分钟 ·2021-04-25 13:43 逻辑运算在代码中基本是必不可少的,Pandas的逻辑运算与Python基础语法中的逻辑运算存在一些差异,所以本文介绍Pandas中的逻辑运算符和逻辑运算。本文使用的数据来源于网易财经,具体下载方法可以参考:Pandas知识点-DataFrame数据结构介绍一、数据准备数据文件是600519.csv,将此文件放到代码同级目录下,从文件中读取出数据。为了使数据简洁一点,删除了数据中的部分列,并设置“日期”为索引。读取的原始数据如上图,本文使用这些数据来介绍Pandas中的逻辑运算。二、Pandas中的逻辑运算符1. 逻辑语句在Pandas中,将Series与数值进行比较,会得到一个与自身形状相同且全为布尔值的Series,每个位置的布尔值对应该位置的比较结果。这种进行比较的代码,返回值是布尔值,是一种布尔表达式,也可以被称为逻辑语句,只要代码返回的结果是布尔值,都可以把代码当成逻辑语句。根据逻辑语句的布尔值,可以用来对数据进行筛选,按我们的需要从大量数据中过滤出目标数据。除了直接的比较,Pandas中有很多函数都会返回布尔值,如all(),any(),isna()等对整个DataFrame或Series的判断结果,eq(),ne(),lt(),gt()等比较函数的结果,都是布尔值。逻辑语句是为逻辑运算服务的,可以直接作为判断条件。在复杂的逻辑关系中,需要使用复合逻辑运算,用逻辑运算符来连接多个逻辑语句,复合逻辑运算包含:逻辑与、逻辑或、逻辑非。2. 逻辑与Pandas中用符号 & 表示逻辑与,连接两个逻辑语句,同时为真才为真。在Python基本语法中,使用 and 表示逻辑与,但是Pandas中只能用 & ,不能用and,会报模糊错误。3. 逻辑或Pandas中用符号 | 表示逻辑或,连接两个逻辑语句,只要其中一个为真就为真。在Python基本语法中,使用 or 表示逻辑或,但是Pandas中只能用 | ,不能用or。4. 逻辑非Pandas中用符号 ~ (键盘左上角)表示逻辑非,对逻辑语句取反。在Python基本语法中,使用 not 表示逻辑非,但是Pandas中只能用 ~ ,不能用not。Python中的逻辑运算关键字(and,or,not)除了可以连接布尔表达式,还可以连接其他的表达式,如字符串等。(and和or可以不计算出右边表达式的布尔值就做出判断,也可以将其中一个表达式作为返回值。另外,Python可以将其他值作为布尔判断条件,如非空字符串表示真。)而Pandas中,逻辑运算符(&, |, ~)只能用于连接布尔表达式,不能处理其他的表达式。另外,在Python的基础语法中,&, |, ~是位运算符,分别表示按位与运算、按位或运算、按位取反运算。三、query()函数逻辑运算是为了方便筛选和过滤数据,使用query()函数可以让逻辑语句更简洁,在query()函数中传入查询字符串,逻辑语句就在查询字符串中。在查询字符串中,进行条件判断不是用列来判断,而是直接用列索引来判断。当多个条件并列时,因为逻辑运算符的优先级高于比较运算符的优先级,每一个逻辑语句的括号也可以省略。以上就是Pandas中的逻辑运算介绍,重点是与Python基本语法的区别,不能用错,而通过query()函数可以使逻辑表达式更加简洁。如果需要本文代码和数据,可以点击关注公众号“Python碎片”,然后在后台回复“pandas08”关键字获取完整代码和数据。 浏览 63点赞 评论 收藏 分享 手机扫一扫分享分享 举报 评论图片表情视频评价全部评论推荐 Pandas知识点-索引和切片操作Python知识圈06个冷门但实用的pandas知识点Crossin的编程教室06个冷门但实用的pandas知识点Python大数据分析06个冷门但实用的pandas知识点小数志0Pandas 的这个知识点,估计 80% 的人都得挂!python爬虫人工智能大数据0Pandas 的这个知识点,估计 80% 的人都得挂!Python绿色通道0Pandas 的这个知识点,估计 80% 的人都得挂!早起Python0PandasPandas0PandasPandas0Pandas东莞市凯保精密机械有限公司成立于2009年,主要生产气动打磨、抛光机及其打磨盘,同时也代理销售日本、台湾等进口品牌工具。公司在发展中得到业界朋友大力支持的同时,吸收国际优秀技术、听取用户的意见,不断自点赞 评论 收藏 分享 手机扫一扫分享分享 举报