我有两个文本文件,每个文件都有一列数据。我想知道是否有办法将两个文件组合在一起,以便特定或所有列并排?可以使用追加来完成吗?
答案 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")
这会将两个文件(称为leftfile
和rightfile
)读入内存,删除前导/尾随空格的两个文件中的每一行,然后按给定的separator
拆分它们。 />
然后重新排列这些列,将它们放回原处并写入输出文件
您可以通过更改order
元组来控制每个文件中的列彼此相邻的顺序。