我有一个多索引的数据帧。我想知道我是否以正确的方式创建了数据帧(见下文)。
01.01 02.01 03.01 04.01
bar total1 40 52 18 11
total2 36 85 5 92
baz total1 23 39 45 70
total2 50 49 51 65
foo total1 23 97 17 97
total2 64 56 94 45
qux total1 13 73 38 4
total2 80 8 61 50
df.index.values
结果:
array([('bar', 'total1'), ('bar', 'total2'), ('baz', 'total1'),
('baz', 'total2'), ('foo', 'total1'), ('foo', 'total2'),
('qux', 'total1'), ('qux', 'total2')], dtype=object)
df.index.get_level_values
结果:
<bound method MultiIndex.get_level_values of MultiIndex(levels=[[u'bar', u'baz', u'foo', u'qux'], [u'total1', u'total2']],
labels=[[0, 0, 1, 1, 2, 2, 3, 3], [0, 1, 0, 1, 0, 1, 0, 1]],names=[]
我最终希望将df转换成字典dict,这样第一个dict键是['bar'、'baz'、'foo'、'qux']之一,值是日期,内部字典是由'total1'和'totals2'组成的键,值是df的整数。 另一种解释,例如,如果dict1是dict,则调用:
dict1['bar']
将导致输出:
{u'bar':{'01.01':{'total1':40,'total2':36},'02.01':{'total1':52,'total2':85},'03.01':{'total1':18,'total2':5},'04.01':{'total1':11,'total2':92} } }
为了实现这一点,我需要改变什么?这是索引问题吗?
要将整个数据帧转换为字典,请尝试:
要转换一个特定列,请在将其转换为字典之前选择,即
相关问题 更多 >
编程相关推荐