感谢您的光临!我希望得到一些帮助使用 pandas 数据框创建 csv。这是我的代码:
a = ldamallet[bow_corpus_new[:21]]
b = data_text_new
print(a)
print("/n")
print(b)
d = {'Preprocessed Document': b['Preprocessed Document'].tolist(),
'topic_0': a[0][1],
'topic_1': a[1][1],
'topic_2': a[2][1],
'topic_3': a[3][1],
'topic_4': a[4][1],
'topic_5': a[5][1],
'topic_6': a[6][1],
'topic_7': a[7][1],
'topic_8': a[8][1],
'topic_9': a[9][1],
'topic_10': a[10][1],
'topic_11': a[11][1],
'topic_12': a[12][1],
'topic_13': a[13][1],
'topic_14': a[14][1],
'topic_15': a[15][1],
'topic_16': a[16][1],
'topic_17': a[17][1],
'topic_18': a[18][1],
'topic_19': a[19][1]}
print(d)
df = pd.DataFrame(data=d)
df.to_csv("test.csv", index=False)
数据:
print(a): 格式为元组
[[(主题数: 0, 主题百分比),...(19, #)], [(下一行的主题分布, #)...(19, .819438),...(# ,#),...]
打印(b)
这是数据框的大小:
任何帮助将不胜感激:)
最佳答案
为它自己的列表中的所有行获取每个元组的第二个值可能是最简单的。像这样
topic_0=[]
topic_1=[]
topic_2=[]
...and so on
for i in a:
topic_0.append(i[0][1])
topic_1.append(i[1][1])
topic_2.append(i[2][1])
...and so on
然后你可以像这样制作你的字典
d = {'Preprocessed Document': b['Preprocessed Document'].tolist(),
'topic_0': topic_0,
'topic_1': topic_1,
etc. }
关于python - 值错误 : arrays must all be same length - print dataframe to CSV,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55639143/