我有兩個 CSV 檔案
csv1:
header
a
b
c
csv2:\
header
e
f
g
我想將這兩個檔案合并到另一個 CSV 中,例如
output.csv:
header
a
e
b
f
c
g
這可以做到嗎?提前致謝
uj5u.com熱心網友回復:
假設 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
uj5u.com熱心網友回復:
肯定不會是最快的方式,但它的作業原理
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()
uj5u.com熱心網友回復:
一種更“傳統”的 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)
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/529502.html
上一篇:如何逐行拆分資料框
