8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

从 MultiIndex 中进行多项随机选择

Swasti Ranjan 1月前

60 0

考虑以下 DataFrame:import pandas as pdarrays = [['A','A','B','B','C','C'],[1,1,3,3,5,5,],[2,2,4,4,6,6],[0.1,0.2,0.3,0.4,0.5,0.6]]index = pd.MultiIndex.from_arrays(arrays,names=('Sa...

考虑以下DataFrame:

import pandas as pd
arrays = [['A','A','B','B','C','C'],[1,1,3,3,5,5,],[2,2,4,4,6,6],[0.1,0.2,0.3,0.4,0.5,0.6]]
index = pd.MultiIndex.from_arrays(arrays,names=('Sample','P1','P2','T'))
data = np.random.rand(10,6)
df = pd.DataFrame(columns=index,data=data)

我想要选择:对于样本 A,选择 T=0.2 的列;对于样本 C,选择 T=0.5 的列。

我可以轻松选择每一列,例如:

df.loc[:,('A',slice(None),slice(None),0.2)]  # or
df.loc(axis=1)[('C',slice(None),slice(None),0.5)] 

但是我该如何将它们结合起来呢?我尝试提供一个元组列表:

df.loc[:,[('A',slice(None),slice(None),0.2),('C',slice(None),slice(None),0.5)]]

但这会产生错误。

我怎样才能选择我的列而不诉诸 pd.concat

帖子版权声明 1、本帖标题:从 MultiIndex 中进行多项随机选择
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由Swasti Ranjan在本站《pandas》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 我喜欢这个答案,因为它简洁明了。它也体现了问题的精神,即列表式的选择。我将把这个作为首选答案。

返回
作者最近主题: