如何从基于pandas中某些列的值的DataFrame中选择行?
在SQL中我将使用:

  1. select * from table where colume_name = some_value.

我试图看看熊猫文档,但没有立即找到答案。

 
要选择列值等于标量some​​_value的行,请使用==:

  1. df.loc[df['column_name'] == some_value]

要选择其列值在可迭代值some_values中的行,请使用isin:

  1. df.loc[df['column_name'].isin(some_values)]

要选择列值不等于some_value的行,请使用!=:

  1. df.loc[df['column_name'] != some_value]

isin返回一个布尔系列,所以要选择值不在some_values的行,使用〜来否定布尔系列:

  1. df.loc[~df['column_name'].isin(some_values)]

例如,

  1. import pandas as pd
  2. import numpy as np
  3. df = pd.DataFrame({'A': 'foo bar foo bar foo bar foo foo'.split(),
  4. 'B': 'one one two three two two one three'.split(),
  5. 'C': np.arange(8), 'D': np.arange(8) * 2})
  6. print(df)
  7. # A B C D
  8. # 0 foo one 0 0
  9. # 1 bar one 1 2
  10. # 2 foo two 2 4
  11. # 3 bar three 3 6
  12. # 4 foo two 4 8
  13. # 5 bar two 5 10
  14. # 6 foo one 6 12
  15. # 7 foo three 7 14
  16. print(df.loc[df['A'] == 'foo'])

产量

  1. A B C D
  2. 0 foo one 0 0
  3. 2 foo two 2 4
  4. 4 foo two 4 8
  5. 6 foo one 6 12
  6. 7 foo three 7 14

如果您想要包含多个值,请将它们放入
列表(或更一般地,任何可迭代),并使用isin:

  1. print(df.loc[df['B'].isin(['one','three'])])

产量

  1. A B C D
  2. 0 foo one 0 0
  3. 1 bar one 1 2
  4. 3 bar three 3 6
  5. 6 foo one 6 12
  6. 7 foo three 7 14

但请注意,如果你想这样做很多次,它是更有效的
首先创建一个索引,然后使用df.loc:

  1. df = df.set_index(['B'])
  2. print(df.loc['one'])

产量

  1. A C D
  2. B
  3. one foo 0 0
  4. one bar 1 2
  5. one foo 6 12

或者,从索引中包含多个值使用df.index.isin:

  1. df.loc[df.index.isin(['one','two'])]

产量

  1. A C D
  2. B
  3. one foo 0 0
  4. one bar 1 2
  5. two foo 2 4
  6. two foo 4 8
  7. two bar 5 10
  8. one foo 6 12

python – 基于pandas中的列中的值从DataFrame中选择行的更多相关文章

  1. EF连接Mysql 表'TableDetails'中的列'IsPrimaryKey'的值为DBNull

    无法生成模型,因为存在以下异常:'System.Data.StrongTypingException:表'TableDetails'中的列'IsPrimaryKey'的值为DBNull.---> ...

  2. Java-Selenium,获取下拉框中的每个选项的值,并随机选择某个选项

    今天逛51testing,看见有人问这个问题.现在以Select标签为例. 1.首先看页面中的下拉框,如图: 2.F12查看页面源代码,如下 <select class="form-c ...

  3. python 将表格多个列数据放到同一个单元格中

      表格模板: 目的将卡片1到卡片5的所有数据组合起来到一个单元格中如下入F列中(工作中为了避免手动复制粘贴),其余不变,因为数据太多 自己一个一个复制工作效率太低,所以写这个脚本是为了方便自己有需要 ...

  4. Python基于pandas的数据处理(一)

    import pandas as pd, numpy as np dates = pd.date_range(', periods=6) df = pd.DataFrame(np.random.ran ...

  5. Python基于pandas的数据处理(二)

    14 抽样 df.sample(10, replace = True) df.sample(3) df.sample(frac = 0.5) # 按比例抽样 df.sample(frac = 10, ...

  6. 【Python + Selenium断言】之如何获取定位Web页面列表中的数据

    如下图所示: 当定位元素时,我想获取指定的某一列的某一行的断言,如图我只想获取jiancha1的值,有同学会说:直接定位不就好了.但是我们知道,列表的数据会时刻变动的,不能靠定死的路径,那该怎么办呢? ...

  7. 数据分析04 /基于pandas的DateFrame进行股票分析、双均线策略制定

    数据分析04 /基于pandas的DateFrame进行股票分析.双均线策略制定 目录 数据分析04 /基于pandas的DateFrame进行股票分析.双均线策略制定 需求1:对茅台股票分析 需求2 ...

  8. Python:pandas(二)——pandas函数

    Python:pandas(一) 这一章翻译总结自:pandas官方文档--General functions 空值:pd.NaT.np.nan //判断是否为空 if a is np.nan: .. ...

  9. Python:pandas(三)——DataFrame

    官方文档:pandas之DataFrame 1.构造函数 用法 pandas.DataFrame( data=None, index=None, columns=None, dtype=None, ) ...

随机推荐

  1. Summary

    PDF 暑假开始准备转移博客,试了几个都不怎么满意(我还去试了下LineBlog 不知道那时候在想什么..),屯着一堆文章,,到时候一起发了 现在暂时转移至WordPress,不过还在完善中,预计.. ...

  2. C#调用WebService的简单方式

    WebServiceCallpublic class WebServiceCall { public void Call() { string url = "http://localhost ...

  3. UVA 1592 DataBase

    思路: 知识补充: ①make_pair和pair: /*pair是将2个数据组合成一个数据,当需要这样的需求时就可以使用pair,如stl中的map就是将key和value放在一起来保存.另一个应用 ...

  4. 网络基础配置--开启SSH,关闭Telnet

    1.Telnet和SSH对比 1.1.TELNET 使用Telnet这个用来访问远程计算机的TCP/IP协议以控制你的网络设备相当于在离开某个建筑时大喊你的用户名和口令.很快会有人进行监听,并且他们会 ...

  5. Android应用程序结构

    综述:Android应用程序包含哪些部分? assets 可以出发一些随程序打包的文件,应用程序运行时可以动态读取到这些文件的内容. 如果使用到webview加载本地网页的功能,所有网页相关的文件都存 ...

  6. php 通用数据库类

    <?php // 数据库连接类 class DB{ //私有的属性 private static $dbcon=false; private $host; private $port; priv ...

  7. 解决 插件LArea 在IOS上浮出软键盘问题

    移动端使用 省市县城市选择三级联动的时候, 插件LArea 会有一个问题 ios浏览器和ie9已下(包括ie9)浏览器都有input设置readonly之后input还有聚焦的问题. ios inpu ...

  8. 更好用的excel国际化多语言导出

    不知道大家在开发中有没有遇到过『excel导出』的需求,反正我最近写了不少这种功能,刚开始利用poi,一行行的手动塞数据,生成excel,而且还有国际化需求,比如:标题栏有一列,用户切换成" ...

  9. Delphi 之弹出气泡消息提示

    //h:窗体中控件的句柄(用在某个控件上提示消息)(要调用的控件句柄) //text:要提示的文本 //cap:提示框上的标题 //IconType:提示框上显示的图标(共三个值.1.2.3分别为提示 ...

  10. @RequestBody, @ResponseBody 注解详解(转)

    原文地址: https://www.cnblogs.com/qq78292959/p/3760651.html @RequestBody, @ResponseBody 注解详解(转) 引言: 接上一篇 ...