pandas合并多个dataframe
收藏
合并两个DataFrame用pd.merge
import pandas as pd
import numpy as np
df1 = pd.DataFrame(np.array([
['a', 1, 2],
['b', 3, 4],
['c', 5, 6]]),
columns=['name', 'num11', 'num12'])
df2 = pd.DataFrame(np.array([
['a', 7, 8],
['b', 9, 10],
['c', 11, 12]]),
columns=['name', 'num21', 'num22'])
df_result = pd.merge(df1, df2, on='name')
print(df_result)
我们可以连续的进行两个两个的合并来实现多个dataframe的合并,是一种使用循环的思想。
from functools import reduce
df1 = pd.DataFrame(np.array([
['a', 1, 2],
['b', 3, 4],
['c', 5, 6]]),
columns=['name', 'num11', 'num12'])
df2 = pd.DataFrame(np.array([
['a', 7, 8],
['b', 9, 10],
['c', 11, 12]]),
columns=['name', 'num21', 'num22'])
df3 = pd.DataFrame(np.array([
['a', 13, 14],
['b', 15, 16],
['c', 17, 18]]),
columns=['name', 'num31', 'num32'])
dfs = [df1, df2, df3]
df_result = reduce(lambda left, right: pd.merge(left, right, on='name'), dfs)
print(df_result)
0
收藏
请登录后评论
大佬厉害