我面临一个挑战,要重新构建一个平面不平衡的层次结构,即自下而上,即将子元素映射到父元素和父元素,等等,转换为自上而下的结构,即从根开始,向下填充结构。因为树是不平衡的,所以有些结束时的层次结构级别比其他的要低。
示例:
来源:
Child|Parent+0|Parent+1|Parent+2|Parent+3|Parent+4
Julia|Peter|Alice|Paul|Sara|Bianca
Chris|Jen|Bob|Fred|Bianca|NaN
Ben|John|Bianca|NaN|NaN 目标:
Parent-0|Parent-1|Parent-2|Parent-3|Parent-4|Child
Bianca|Sara|Paul|Alice|Peter|Julia
Bianca|Fred|Bob|Jen|NaN|Chris
Bianca|John|NaN|NaN|NaN|Ben 我尝试过不同的想法,但到目前为止还没有成功。感谢你的帮助或想法。
发布于 2019-10-09 19:33:47
set_index并翻转值。然后使用从Divakar修改的justify函数。
df = df.set_index('Child').loc[:, ::-1]
pd.DataFrame(justify(df.to_numpy(), invalid_val=np.NaN),
index=df.index,
columns=[f'Parent-{i}' for i in range(0, df.shape[1])]) Parent-0 Parent-1 Parent-2 Parent-3 Parent-4
Child
Julia Bianca Sara Paul Alice Peter
Chris Bianca Fred Bob Jen NaN
Ben Bianca John NaN NaN NaNhttps://stackoverflow.com/questions/58309845
复制相似问题