我有两个CSV文件
csv1:
header
a
b
c
csv2:
header
e
f
g
我想将这两个文件合并到另一个CSV文件中,如
output.csv:
header
a
e
b
f
c
g
这能做到吗?提前感谢
更"传统的";不需要任何外部依赖的Python方法。
with open("csv1.txt") as f1, open("csv2.txt") as f2, open("output.txt", "w") as fo:
csv1, csv2 = f1.readlines(), f2.readlines()
header, _ = csv1.pop(0), csv2.pop(0)
output = [header]
for i in range(min(len(csv1),len(csv2))):
output.extend([csv1[i], csv2[i]])
fo.writelines(output)
肯定不是最快的方式,但它是有效的
import pandas as pd
from itertools import chain, zip_longest
x = pd.DataFrame()
x["header"] = [1, 3, 5, 7]
y = pd.DataFrame()
y["header"] = [2, 4, 6, 8, 10, 21]
chained = list(chain.from_iterable(zip_longest(x["header"].to_list(), y["header"].to_list())))
df = pd.DataFrame()
df["header"] = chained
df = df.dropna()
假设csv 1读取到df1
假设csv 2读到df2
df1 = pd.DataFrame({'header': ['a', 'b', 'c']})
df2 = pd.DataFrame({'header': ['d', 'e', 'f']})
print(pd.concat(
[df1, df2], axis=1
).stack().reset_index(1, drop=True))
输出# 0 a
0 d
1 b
1 e
2 c
2 f