创建具有 MultiIndex 列的 DataFrame 时,似乎无法使用类似df[df["AA"]>0.0]
. 例如:
import pandas as pd
import numpy as np
dates = np.asarray(pd.date_range('1/1/2000', periods=8))
_metaInfo = pd.MultiIndex.from_tuples([('AA', '[m]'), ('BB', '[m]'), ('CC', '[s]'), ('DD', '[s]')], names=['parameter','unit'])
df = pd.DataFrame(randn(8, 4), index=dates, columns=_metaInfo)
print df[df['AA']>0.0]
df["AA"]>0.0 的结果是一个索引 DataFrame iso 一个 Timeseries。这可能会导致崩溃。
当使用相同的 metaInfo 作为行的索引时,情况有所不同:
df1 = pandas.DataFrame(np.random.randn(4, 6), index=_metaInfo)
print df1[df1["AA"]>0.0]
产生:
[ 1.13268106 -0.06887761 0.68535054 2.49431163 -0.29349413 0.34772553]
AA 行中大于零的元素。这仅给出 AA 行的值,而不给出 DataFrame 的其他列的值。
有解决方法吗?我是否正在尝试做我不应该做的事情?