作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想将软件提供的 DataFrame 转换为更适合 Python 的 DataFrame,但我无法使用 pandas 以简单的方式修复它,因为我必须使用列中包含的信息。这里有一个简单的例子:
import pandas as pd
d = {'00' : [1],'01' : [11], '10': [111], '11':[1111]}
pd.DataFrame(d)
00 01 10 11
0 1 11 111 1111
列名包含我需要在行中使用的因素,我想得到这样的东西:
df = {'trt': [0,0,1,1], 'grp': [0,1,0,1], 'value':[1,11,111,1111]}
pd.DataFrame(df)
grp trt value
0 0 0 1
1 1 0 11
2 0 1 111
3 1 1 1111
关于如何正确执行它的任何想法?
最佳答案
解决方案 MultiIndex.from_arrays
已创建 indexing with str并通过 T
进行转置:
df.columns = pd.MultiIndex.from_arrays([df.columns.str[0], df.columns.str[1]])
print (df)
0 1
0 1 0 1
0 1 11 111 1111
df1 = df.T.reset_index()
df1.columns = ['grp','trt','value']
print (df1)
grp trt value
0 0 0 1
1 0 1 11
2 1 0 111
3 1 1 1111
与 rename_axis
类似的解决方案并重命名 index
:
d = {'00' : [1],'01' : [11], '10': [111], '11':[1111]}
df = pd.DataFrame(d)
df.columns = pd.MultiIndex.from_arrays([df.columns.str[0], df.columns.str[1]])
print(df.rename_axis(('grp','trt'), axis=1).rename(index={0:'value'}).T.reset_index())
grp trt value
0 0 0 1
1 0 1 11
2 1 0 111
3 1 1 1111
关于python - 使用列名作为因子有效地转换 pandas dataFrame,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40933921/
我是一名优秀的程序员,十分优秀!