DataFrame(7):DataFrame运算——逻辑运算
时间:2022-07-22
本文章向大家介绍DataFrame(7):DataFrame运算——逻辑运算,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
1、DataFrame逻辑运算
- 逻辑运算符号:> >= < <= == !=
- 复合逻辑运算符:& | ~
- 逻辑运算函数:query()、isin()、between()
- 逻辑运算的作用:利用逻辑运算,用于筛选数据(很重要)
2、原始数据文件
下载链接:
https://alltodata.cowtransfer.com/s/b8aa2f26ca0947
读取数据:
df = pd.read_excel(r"C:Users黄伟Desktoptest.xlsx")
display(df)
结果如下:
3、逻辑运算符的案例说明
1)筛选出“数学成绩大于等于60并且英语成绩大于等于70”的记录
df = pd.read_excel(r"C:Users黄伟Desktoptest.xlsx")
display(df)
x = (df["数学"]>=60) & (df["英语"]>=70)
display(x)
df1 = df[(df["数学"]>=60) & (df["英语"]>=70)]
display(df1)
结果如下:
2)筛选出“语文成绩小于60或者数学成绩大于80”的记录
df = pd.read_excel(r"C:Users黄伟Desktoptest.xlsx")
display(df)
x = (df["语文"]<60) | (df["数学"]>80)
display(x)
df1 = df[(df["语文"]<60) | (df["数学"]>80)]
display(df1)
结果如下:
3)筛选出“语文成绩里面的非空记录”的记录
(这种方式很重要)
# 自己在原始数据中,任意删除三个值,重新读取即可
df = pd.read_excel(r"C:Users黄伟Desktoptest.xlsx")
display(df)
x = df["语文"].isnull()
display(x)
y = ~df["语文"].isnull()
display(y)
df1 = df[~df["语文"].isnull()]
display(df1)
结果如下:
注意:isnull()判断某个值是否为空,如果是返回True,否则返回False。
4、逻辑运算函数:query()、isin()、between()
1)query()函数:能够简化查询代码,很好用
df = pd.read_excel(r"C:Users黄伟Desktoptest.xlsx")
display(df)
df1 = df.query("语文>=60")
df1
df1 = df.query("语文>=60 & 数学>=60")
df1
结果如下:
2)isin()函数:查看df中是否某含某个值或者某些值
① isin()函数说明
使用isin()函数,不仅可以针对整个df操作,也可以针对df中的某一列(Series)操作,但是针对Series的操作才是最常用的。
② 利用isin()判断整个df中是否包含某个值或某些值(了解)
df = pd.read_excel(r"C:Users黄伟Desktoptest.xlsx")
display(df)
df.isin(["60","70"])
结果如下:
③ 利用isin()判断df中的某列是否包含某个值或某些值(掌握)
df = pd.read_excel(r"C:Users黄伟Desktoptest.xlsx")
display(df)
df["语文"].isin(["37","97"])
df1 = df[df["语文"].isin(["37","97"])]
display(df1)
结果如下:
④ 利用isin(),利用df1中的某一列,来对df2中的数据进行过滤(很重要)
df1 = pd.read_excel(r"C:Users黄伟Desktoptest.xlsx",sheet_name=0)
display(df1)
df2 = pd.read_excel(r"C:Users黄伟Desktoptest.xlsx",sheet_name=1)
display(df2)
x = df1["name"].isin(df2["name"])
display(x)
df1[df1["name"].isin(df2["name"])]
结果如下:
3)between()函数:返回一个布尔值,即如果在该范围内,返回True,否则返回False。
df = pd.read_excel(r"C:Users黄伟Desktoptest.xlsx",sheet_name=0)
display(df)
df["数学"].between(50,70)
df[df["数学"].between(50,70)]
结果如下:
注意:此函数范围是左闭右闭区间。
- hihoCoder #1078 : 线段树的区间修改(线段树区间更新板子题)
- HDU 2546 饭卡(01背包裸题)
- 漫谈文件系统
- AI知识搜索利器:基于ElasticSearch构建专知实时高性能搜索系统
- 【深度干货】专知主题链路知识推荐#5-机器学习中似懂非懂的马尔科夫链蒙特卡洛采样(MCMC)入门教程01
- hihoCoder #1043 : 完全背包(板子题)
- 【深度干货】专知主题链路知识推荐#7-机器学习中似懂非懂的马尔科夫链蒙特卡洛采样(MCMC)入门教程02
- hihoCoder #1038 : 01背包(板子题)
- 最小二乘法多项式曲线拟合原理与实现
- HDU 1166 敌兵布阵(线段树单点更新,板子题)
- 一文看懂ovirt的supervdsmd服务
- openstack如何扩展API之二:扩展原有核心API
- selenium+python自动化77-autoit文件上传
- selenium+python自动化78-autoit参数化与批量上传
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- android 调试 adb
- Java实现基本数据结构(三)——队列
- Java实现基本数据结构(二)——栈
- Java实现基本数据结构(一)——数组
- concurrently 实现前后端连载启动
- Vue+Koa2 前后端分离项目线上部署
- Nativefier— 将网站打包成桌面程序
- JAVA反射功能
- Git
- Bootstrap实用功能总结
- Bootstrap基础学习笔记
- 基于Paddle Lite在Android手机上实现图像分类
- redis学习笔记-set
- 图解一致性哈希算法,全网(小区局域网)最通俗易懂
- ES 创建索引时使用Dynamic Mapping动态映射 对字符串字段生成keyword字段