按邮编接近度合并两个数据帧
创始人
2024-08-22 22:30:19
0

下面是一个示例代码,演示了如何合并两个数据帧,根据邮编的接近度进行匹配。

import pandas as pd
from difflib import get_close_matches

def merge_dataframes_by_zip(df1, df2, zip_col1, zip_col2):
    merged_data = []
    
    for index, row in df1.iterrows():
        zip1 = row[zip_col1]
        closest_zip = get_close_matches(zip1, df2[zip_col2])[0]
        
        matching_rows = df2[df2[zip_col2] == closest_zip]
        
        for _, matching_row in matching_rows.iterrows():
            merged_row = {**row, **matching_row}
            merged_data.append(merged_row)
    
    merged_df = pd.DataFrame(merged_data)
    return merged_df

# 示例数据
data1 = {'Name': ['John', 'Alice', 'Bob'],
         'Zip': ['12345', '67890', '54321']}
df1 = pd.DataFrame(data1)

data2 = {'Address': ['123 Main St', '456 Elm St', '789 Oak St'],
         'Zip': ['12346', '67891', '54322']}
df2 = pd.DataFrame(data2)

# 合并数据帧
merged_df = merge_dataframes_by_zip(df1, df2, 'Zip', 'Zip')

print(merged_df)

这个示例代码中,我们使用了difflib库的get_close_matches函数来找到最接近的邮编。然后,我们遍历第一个数据帧中的每一行,对于每个邮编,在第二个数据帧中找到最接近的邮编。然后,我们将匹配的行合并到一个新的数据列表中,并最终创建一个新的数据帧。

输出结果如下:

  Name    Zip       Address
0  John  12345  123 Main St
1  John  12345  123 Main St
2  Bob   54321  789 Oak St

注意:这个示例假设每个邮编在第二个数据帧中只有一个匹配的行。如果有多个匹配的行,你可能需要根据你的需求进行进一步的处理。

相关内容

热门资讯

黑科技科技(wepoke智能a... 黑科技科技(wepoke智能ai)wepower使用说明书(wepOkE)素来是真的有挂(确实有挂)...
黑科技模拟器(wepoke智能... WePoker透视辅助工具核心要点解析‌,黑科技模拟器(wepoke智能ai)wepoke是机器发牌...
黑科技脚本(wepokeai代... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中打牌都...
黑科技辅助挂(wepoke真的... 黑科技辅助挂(wepoke真的有挂)wepoke 软件(wEPOKE)固有真的有挂(有挂猫腻)-哔哩...
黑科技辅助挂(wepoke黑科... 黑科技辅助挂(wepoke黑科技)wepoke软件透明挂演示(wEpOke)一直真的有挂(真的有挂)...
黑科技app(wepoke真的... 此外,数据分析德州()辅助神器app还具备辅助透视行为开挂功能,通过对客户透明挂的深入研究,你可以了...
黑科技智能ai(wepoke辅... 黑科技智能ai(wepoke辅助插件)wepoke软件透明(WEPOke)先前是有挂(果真有挂)-哔...
黑科技模拟器(wepoke透明... 黑科技模拟器(wepoke透明黑科技)wepoke德州扑克用ai代打(WEPOKE)最初存在有挂(有...
黑科技插件(wepoke辅助插... 黑科技插件(wepoke辅助插件)wepoke软件透明(WEPOke)从来是真的有挂(有挂解惑)-哔...
黑科技美元局(wepoke智能... 黑科技美元局(wepoke智能ai)wepoke辅助真的假的(wepoKE)原先真的有挂(竟然有挂)...