python - 将 Pandas 系列输出到txt文件

标签 python pandas numpy dataframe file-io

我有一个 Pandas 系列对象

<class 'pandas.core.series.Series'>

看起来像这样:

userId
1          3072 1196 838 2278 1259
2               648 475 1 151 1035
3               457 150 300 21 339
4          1035 7153 953 4993 2571
5           260 671 1210 2628 7153
6          4993 1210 2291 589 1196
7               150 457 111 246 25
8       1221 8132 30749 44191 1721
9           296 377 2858 3578 3256
10          2762 377 2858 1617 858
11           527 593 2396 318 1258
12        3578 2683 2762 2571 2580
13        7153 150 5952 35836 2028
14        1197 2580 2712 2762 1968
15        1245 1090 1080 2529 1261
16         296 2324 4993 7153 1203
17       1208 1234 6796 55820 1060
18            1377 1 1073 1356 592
19           778 1173 272 3022 909
20              329 534 377 73 272
21            608 904 903 1204 111
22       1221 1136 1258 4973 48516
23        1214 1200 1148 2761 2791
24             593 318 162 480 733
25               314 969 25 85 766
26        293 253 4878 46578 64614
27          1193 2716 24 2959 2841
28         318 260 58559 8961 4226
29            318 260 1196 2959 50
30        1077 1136 1230 1203 3481

642            123 593 750 1212 50
643         750 671 1663 2427 5618
644            780 3114 1584 11 62
645         912 2858 1617 1035 903
646           608 527 21 2710 1704
647         1196 720 5060 2599 594
648         46578 50 745 1223 5995
649            318 300 110 529 246
650            733 110 151 318 364
651         1240 1210 541 589 1247
652      4993 296 95510 122900 736
653            858 1225 1961 25 36
654        333 1221 3039 1610 4011
655           318 47 6377 527 2028
656          527 1193 1073 1265 73
657             527 349 454 357 97
658            457 590 480 589 329
659              474 508 1 288 477
660         904 1197 1247 858 1221
661           780 1527 3 1376 5481
662             110 590 50 593 733
663          2028 919 527 2791 110
664    1201 64839 1228 122886 1203
665        1197 858 7153 1221 6539
666            318 300 161 500 337
667            527 260 318 593 223
668            161 527 151 110 300
669          50 2858 4993 318 2628
670          296 5952 508 272 1196
671         1210 1200 7153 593 110

将此输出到 txt 文件(例如 output.txt)以使格式看起来像这样的最佳方法是什么?

User-id1 movie-id1 movie-id2 movie-id3 movie-id4 movie-id5
User-id2 movie-id1 movie-id2 movie-id3 movie-id4 movie-id5

最左边的值是用户 ID,其他值是电影 ID。

这是生成上述内容的代码:

import pandas as pd
from sklearn.metrics.pairwise import cosine_similarity
import numpy as np

def predict(l):
    # finds the userIds corresponding to the top 5 similarities
    # calculate the prediction according to the formula
    return (df[l.index] * l).sum(axis=1) / l.sum()


# use userID as columns for convinience when interpretering the forumla
df = pd.read_csv('ratings.csv').pivot(columns='userId',
                                                index='movieId',
                                                values='rating')
df = df - df.mean()
similarity = pd.DataFrame(cosine_similarity(
    df.T.fillna(0)), index=df.columns, columns=df.columns)

res = df.apply(lambda col: ' '.join('{}'.format(mid) for mid in (0 * col).fillna(
    predict(similarity[col.name].nlargest(6).iloc[1:])).nlargest(5).index))



#Do not understand why this does not work for me but works below
df = pd.DataFrame.from_items(zip(res.index, res.str.split(' ')))
#print(df)
df.columns = ['movie-id1', 'movie-id2', 'movie-id3', 'movie-id4', 'movie-id5']
df['customer_id'] = df.index
df = df[['customer_id', 'movie-id1', 'movie-id2', 'movie-id3', 'movie-id4', 'movie-id5']]
df.to_csv('filepath.txt', sep=' ', index=False)

我尝试实现@emmet02 解决方案但出现此错误,但我不明白为什么会出现此错误:

ValueError: Length mismatch: Expected axis has 671 elements, new values have 5 elements

非常感谢任何建议,如果您需要更多信息或说明,请告诉我。

最佳答案

我建议先将您的 pd.Series 转换为 pd.DataFrame。

df = pd.DataFrame.from_items(zip(series.index, series.str.split(' '))).T

只要系列具有相同数量的值(对于每个条目!),以空格分隔,这将返回此格式的数据帧

Out[49]: 
      0     1    2     3     4
0  3072   648  457  1035   260
1  1196   475  150  7153   671
2   838     1  300   953  1210
3  2278   151   21  4993  2628
4  1259  1035  339  2571  7153

接下来我会适本地命名列

df.columns = ['movie-id1', 'movie-id2', 'movie-id3', 'movie-id4', 'movie-id5']

最后,数据框由客户 ID 索引(我假设这是基于您的系列索引)。我们想将其移动到数据框中,然后重新组织列。

df['customer_id'] = df.index
df = df[['customer_id', 'movie-id1', 'movie-id2', 'movie-id3', 'movie-id4', 'movie-id5']]

现在这给你留下了一个像这样的数据框

  customer_id movie-id1 movie-id2 movie-id3 movie-id4 movie-id5
0            0      3072       648       457      1035       260
1            1      1196       475       150      7153       671
2            2       838         1       300       953      1210
3            3      2278       151        21      4993      2628
4            4      1259      1035       339      2571      7153

我建议您使用

作为 csv 写入磁盘
df.to_csv('filepath.csv', index=False)

但是如果你想将它写成一个文本文件,只用空格分隔,你可以使用相同的函数,但传递分隔符。

df.to_csv('filepath.txt', sep=' ', index=False)

我不认为 Series 对象是您要解决的问题的正确数据结构选择。在我看来,将数字数据视为数字数据(以及在 DataFrame 中)比维护“空格分隔的字符串”转换要容易得多。

关于python - 将 Pandas 系列输出到txt文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48831802/

相关文章:

python - 如何使用 update() 方法对 Python Pandas Dataframe 中的 collection.Counter 对象求和?

python - 对数据框进行操作以将行转换为单独的列

Python如何使用defaultdict创建列表字典的字典

python pandas 选择头部和尾部

python - 如何在 GAME 中检查记录是否存在

python - 从最后一行到第一行遍历 python pandas 数据框

python - numpy: bool 索引和内存使用

python - 如何确保两个Python列表中的元素数量相等?

python - 使用CNN和两个输入进行预测

python子进程的使用