如何使用python将2个文本文件合并到一个新文件中?

时间:2012-11-13 15:10:54

标签: python-3.x python-2.7

我有两个文本文件,每个文件都有一列数据。我想知道是否有办法将两个文件组合在一起,以便特定或所有列并排?可以使用追加来完成吗?

2 个答案:

答案 0 :(得分:0)

我会使用csv module来读取这两个文件,按键将数据放入字典中,然后再次使用csv模块编写带有连接数据的文件。

答案 1 :(得分:0)

假设您的两个文件具有完全相同的行数,您可以执行以下操作:

# column 0 in right file next to column 0 in left file
# column 1 in right file next to column 1 in left file
# column 2 in right file next to column 2 in left file
order = (0, 0), (1, 1), (2, 2)
contents = [] # contains left side file content in idx 0, right side in idx 1
for fname in ("leftfile", "rightfile"):
    with open(fname) as f:
        contents.append(f.readlines()) # read entire file content

separator = " " # what separates the columns?
with open("out", "w") as outfile:
    for row in range(len(contents[0])):
        cl = contents[0][row].strip().split(separator) # columns in left file
        cr = contents[1][row].strip().split(separator) # columns in right file
        outfile.writelines(
                separator.join("%s%s%s" % (cl[l], separator, cr[r])
                    for l, r in order))
        outfile.write("\n")

这会将两个文件(称为leftfilerightfile)读入内存,删除前导/尾随空格的两个文件中的每一行,然后按给定的separator拆分它们。 /> 然后重新排列这些列,将它们放回原处并写入输出文件 您可以通过更改order元组来控制每个文件中的列彼此相邻的顺序。