选择 pandas 中多索引列的子级别

2024-02-29

我生成一个像这个例子一样的多索引数据框

import pandas as pd
import numpy as np

iterables = [ ['co1', 'co2', 'co3', 'co4'], ['age','weight'] ]
multi = pd.MultiIndex.from_product(iterables, names= ["Spread", "attribute"])

df = pd.DataFrame(np.random.rand(80).reshape(10,8),index = range(0,10), columns = multi)

每个列都有一个名为“权重”的子级别属性

我需要生成一个列表或(最好)系列,其中包含给定行的所有“权重”子列。在示例图片中,我想要一个给我 0.02、0.46、0.33、0.47 的系列。

谁能建议一个好方法来做到这一点?我想到的解决方案都很粗糙,我怀疑我对 pandas 的索引功能理解不完全。


IIUC 然后你可以使用loc并传递一个由以下组成的元组slice和列标签来访问该级别感兴趣的列:

In [59]:
iterables = [ ['co1', 'co2', 'co3', 'co4'], ['age','weight'] ]
multi = pd.MultiIndex.from_product(iterables, names= ["Spread", "attribute"])
df = pd.DataFrame(np.random.rand(80).reshape(10,8),index = range(0,10), columns = multi)
df

Out[59]:
Spread          co1                 co2                 co3            \
attribute       age    weight       age    weight       age    weight   
0          0.600947  0.509537  0.605538  0.496002  0.215206  0.075079   
1          0.152956  0.922832  0.167788  0.024761  0.622378  0.983030   
2          0.712478  0.603798  0.407014  0.625474  0.445592  0.903240   
3          0.420569  0.576604  0.220097  0.401624  0.929464  0.512026   
4          0.273088  0.032303  0.607577  0.836231  0.751845  0.181522   
5          0.859699  0.274760  0.456812  0.666109  0.349961  0.237894   
6          0.632754  0.603252  0.157416  0.221576  0.068355  0.121864   
7          0.090595  0.035526  0.698262  0.525770  0.792618  0.220601   
8          0.670236  0.805195  0.310680  0.100464  0.875299  0.853238   
9          0.020501  0.405245  0.447614  0.999340  0.659616  0.709312   

Spread          co4            
attribute       age    weight  
0          0.297421  0.415730  
1          0.235259  0.156014  
2          0.365762  0.198299  
3          0.695431  0.478457  
4          0.331657  0.338436  
5          0.943810  0.097999  
6          0.638720  0.033747  
7          0.646969  0.475316  
8          0.623225  0.024976  
9          0.023494  0.959514  

In [61]:
df.loc[1,(slice(None),'weight')]

Out[61]:
Spread  attribute
co1     weight       0.922832
co2     weight       0.024761
co3     weight       0.983030
co4     weight       0.156014
Name: 1, dtype: float64

为了解释syntax http://pandas.pydata.org/pandas-docs/stable/advanced.html#using-slicers:

df.loc[1,(slice(None),'weight')]

所以第一个参数只是你的索引 lave,第二个参数是一个由切片和 col 标签组成的元组,第一个成员是slice(None)选择有效的所有列“col1”到“col4”,然后第二个参数选择与标签“weight”匹配的下一级 cols

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

选择 pandas 中多索引列的子级别 的相关文章

随机推荐

  • 是否可以在运行时通过反射“探索”另一个对象中定义了哪些对象?

    考虑这段代码 object A object AA extends A object AB extends A object AC extends A class A 如何 看到 对象中定义的对象A在运行时 我想到了一个方法object A
  • Google Maps API,需要购买吗? [关闭]

    Closed 这个问题是无关 help closed questions 目前不接受答案 我目前正在创建一个应用程序 iPhone iPad Android 它使用地图来显示租赁公司提供的房屋 该应用程序是free在所有商店 我已阅读条款并
  • Laravel 密码验证规则

    如何在验证器中添加密码验证规则 验证规则 密码包含以下五类中至少三类的字符 英文大写字符 A Z 英文小写字符 a z 10 基数 0 9 非字母数字 例如 或 统一码字符 如何在验证器规则中添加上述规则 我的代码在这里 create th
  • 在 php 中用分号分割 sql 语句(但不在引号内)

    当用户在自由格式字段中使用分号时 我的系统会导致错误 我将其追溯到一个简单的爆炸语句 array explode sql 因为该行位于从整个系统调用的子例程中 所以我想用可以正确拆分事物的内容替换该行 而不会破坏系统的其余部分 我认为 st
  • 在版本控制中维护 Visual Studio vcproj 项目文件的建议

    Microsoft Visual Studio 使用 XML 来保存其 vcproj项目文件 所以比较 XML 项目文件should很容易 不幸的是 如果您更改项目文件的任何属性 Visual Studio 会坚持随机打乱项目文件的 XML
  • 使用 Python Tkinter 通过单击按钮更改图像[重复]

    这个问题在这里已经有答案了 我想在按下按钮时显示 2 个不同的图像 我有两张图片和相应的 2 个按钮 我正在使用面板的配置功能来尝试更改图像 但无济于事 我将如何实现这个目标 谢谢你 import Tkinter as tk from PI
  • C++ 中的二义性函数

    我想知道为什么这些声明不起作用 不兼容 void f int p1 void f const int p2 void f int p3 void f const int p4 如果我理解得很好 编译器不会发现 int 和 const int
  • Python - 模拟链式函数调用

    我在单元测试下的方法之一中有以下声明 db employees self db session query Employee filter Employee dept new employee dept all 我希望 db employe
  • 有没有一种简单的方法可以在 Android Studio 中查看颜色?

    如果我搜索一种颜色 它会返回结果R java public static final int cardview light background 0x7f040027 如何查看此颜色代码 这是一个 ARGB 代码 我很难找到它 有没有简单的
  • 具有 View 属性的 SwiftUI 协议返回错误“类型‘任何视图’不能符合‘视图’”

    我想定义一个协议 该协议具有要从主视图层次结构中使用的视图属性 我定义了一个协议 该协议返回带有关联视图类型的 ViewBuilder 属性包装器 protocol protocol SimpleProtocol associatedtyp
  • 如何从图例中删除已使用的值?

    In Brief 我知道scale drop TRUE 可用于从图例中删除空因子水平 也许违反直觉 我试图放弃used情节的水平 正如您可能已经猜到的 这是一个稍微有点 hack 的用例 我使用隐形条geom bar抵消 浮动 的李克特反应
  • 在我的 CustomListAdapter 上实现 Filterable 接口后无法重新加载 ListView 内容

    我在这里有两个问题 第一个问题是 我实施后Filterable我的 CustomListAdapter 中的接口启用对列表数据的搜索 我意识到每次我尝试重新加载列表视图时 它都拒绝填充列表视图 即使我能够从服务器获取数据 我的 ListVi
  • UIActionSheet 单击/点击外部时关闭

    我是 iPhone 开发新手 谁能告诉我当我点击 UIActionSheet 控件外部时如何关闭它 在我的actionSheet中 我只有datePicker控件 它会在选项卡栏控件上弹出 现在每当用户在其外部单击时 它都应该关闭 而不是使
  • 将 Python 嵌入 C++

    Problem 将 Python 嵌入 C 时抛出奇怪的异常 Program bool embedd execute python std string location if std ifstream location const cha
  • Xcode 6 AFURLRequestSerialization 中的自动合成错误

    如何修复我在 Xcode 6 beta 上使用最新 AFNetworking 获得的属性streamStatus和streamError的警告 自动属性合成不会合成 因为它是可读写的 但它将通过另一个属性只读合成 https github
  • 使用 MiniProfiler 进行直接 ADO.net 调用

    对于那些 C 和分析器极客来说 这个问题很愚蠢 我是 C 新手 基本上是 C 开发人员 如果使用的话我可以分析数据库查询dbproviderfactory 但我无法在直接使用 ado net 调用时分析它 原始SqlConnection S
  • GlobalSession 范围的 beans 是否从 spring 5 中删除了?为什么?

    1 Spring 5 中是否删除了全局会话范围的 beans 官方文档不再提及 SCOPE GLOBAL SESSION 不再是 RequestAttributes 的一部分 春季 4 https docs spring io autore
  • 无法在 OSX yosemite 上构建 Java 项目

    我被以下错误阻止 com sun tools javac util Context put Ljava lang Class Ljava lang Object V 这是完整的跟踪 project git master gradle jar
  • Ruby 中的计时器性能

    我正在寻找一个演示 ruby 计时器的在线示例 并发现了下面的代码 它按预期工作 但是这个简单的程序使用 30Mo 内存 如 Windows 任务管理器中所示 和太多的 CPU 有意义吗 多谢 def time block start ti
  • 选择 pandas 中多索引列的子级别

    我生成一个像这个例子一样的多索引数据框 import pandas as pd import numpy as np iterables co1 co2 co3 co4 age weight multi pd MultiIndex from