如何从 HDFStore 检索 pandas df multiindex?
How to retrieve pandas df multiindex from HDFStore?
如果是简单索引的DataFrame,可以按如下方式从HDFStore中获取索引:
df = pd.DataFrame(np.random.randn(2, 3), index=list('yz'), columns=list('abc'))
df
>>> a b c
>>> y -0.181063 1.919440 1.550992
>>> z -0.701797 1.917156 0.645707
with pd.HDFStore('test.h5') as store:
store.put('df', df, format='t')
store.select_column('df', 'index')
>>> 0 y
>>> 1 z
>>> Name: index, dtype: object
如 docs 中所述。
但在使用 MultiIndex 的情况下,这种技巧不起作用:
df = pd.DataFrame(np.random.randn(2, 3),
index=pd.MultiIndex.from_tuples([(0,'y'), (1, 'z')], names=['lvl0', 'lvl1']),
columns=list('abc'))
df
>>> a b c
>>> lvl0 lvl1
>>> 0 y -0.871125 0.001773 0.618647
>>> 1 z 1.001547 1.132322 -0.215681
更确切地说是returns 错误 索引:
with pd.HDFStore('test.h5') as store:
store.put('df', df, format='t')
store.select_column('df', 'index')
>>> 0 0
>>> 1 1
>>> Name: index, dtype: int64
如何检索正确的 DataFrame MultiIndex?
可以使用 select
并指定 columns=['index']
参数:
df = pd.DataFrame(np.random.randn(2, 3),
index=pd.MultiIndex.from_tuples([(0,'y'), (1, 'z')], names=['lvl0', 'lvl1']),
columns=list('abc'))
df
>>> a b c
>>> lvl0 lvl1
>>> 0 y -0.871125 0.001773 0.618647
>>> 1 z 1.001547 1.132322 -0.215681
with pd.HDFStore('test.h5') as store:
store.put('df', df, format='t')
store.select('df', columns=['index'])
>>> lvl0 lvl1
>>> 0 y
>>> 1 z
有效,但似乎无效 documented。
如果是简单索引的DataFrame,可以按如下方式从HDFStore中获取索引:
df = pd.DataFrame(np.random.randn(2, 3), index=list('yz'), columns=list('abc'))
df
>>> a b c
>>> y -0.181063 1.919440 1.550992
>>> z -0.701797 1.917156 0.645707
with pd.HDFStore('test.h5') as store:
store.put('df', df, format='t')
store.select_column('df', 'index')
>>> 0 y
>>> 1 z
>>> Name: index, dtype: object
如 docs 中所述。
但在使用 MultiIndex 的情况下,这种技巧不起作用:
df = pd.DataFrame(np.random.randn(2, 3),
index=pd.MultiIndex.from_tuples([(0,'y'), (1, 'z')], names=['lvl0', 'lvl1']),
columns=list('abc'))
df
>>> a b c
>>> lvl0 lvl1
>>> 0 y -0.871125 0.001773 0.618647
>>> 1 z 1.001547 1.132322 -0.215681
更确切地说是returns 错误 索引:
with pd.HDFStore('test.h5') as store:
store.put('df', df, format='t')
store.select_column('df', 'index')
>>> 0 0
>>> 1 1
>>> Name: index, dtype: int64
如何检索正确的 DataFrame MultiIndex?
可以使用 select
并指定 columns=['index']
参数:
df = pd.DataFrame(np.random.randn(2, 3),
index=pd.MultiIndex.from_tuples([(0,'y'), (1, 'z')], names=['lvl0', 'lvl1']),
columns=list('abc'))
df
>>> a b c
>>> lvl0 lvl1
>>> 0 y -0.871125 0.001773 0.618647
>>> 1 z 1.001547 1.132322 -0.215681
with pd.HDFStore('test.h5') as store:
store.put('df', df, format='t')
store.select('df', columns=['index'])
>>> lvl0 lvl1
>>> 0 y
>>> 1 z
有效,但似乎无效 documented。