吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 750|回复: 12
收起左侧

[Python 原创] 用Python实现文本相似度最大化匹配

[复制链接]
dommy 发表于 2024-8-1 13:46
本帖最后由 dommy 于 2024-8-1 14:07 编辑

因工作需要,对原有客商开户信息匹配上联行号(已有一份行名+联行号基础数据),但即有客商开户信息录入五花八门,通过Excel的VLOOKUP精确处理只得到很小一部分有用信息,但其模糊匹配功能处理结果差强人意,于是用Python做了一个相似度匹配。
运行后的结果如下图(当前截图以工行为例,因数据量大,“工行”二字已删除以提高效率):

处理后的结果

处理后的结果


源代码如下:

import pandas as pd  
from fuzzywuzzy import process  

#读取Excel文件  
file_path = 'C:\\Users\\mwm\\Documents\\gonghang.xlsx'  # 替换为你的Excel文件路径  
df = pd.read_excel(file_path)  

#假设你的原文本列名为'SourceText',目标文本列名为'TargetText'  
source_column = 'SourceText'  # 替换为你的原文本列名  
target_column = 'TargetText'  # 替换为你的目标文本列名  
closest_match_column = 'ClosestMatch'  # 新列名,用于存储最相似的文本  
similarity_column = 'Similarity'  # 新列名,用于存储相似度得分  

#计算相似度,并找到最相似的文本  
def find_closest_matches(source_texts, target_texts):  
    closest_matches = []  
    similarities = []  
    i = 0

    for source in source_texts:  
        closest = process.extractOne(source, target_texts)  
        closest_matches.append(closest[0])  
        similarities.append(closest[1])  
        i = i + 1
        if i % 100 == 0:
            print("已处理 %d 行数据" % i)

    return closest_matches, similarities  

#过滤空值和空白值  
non_empty_source_texts = [text for text in df[source_column] if pd.notna(text) and text.strip()]  
non_empty_target_texts = df[target_column].tolist()  # 假设目标列也需要处理,但通常我们保留所有目标文本  

#应用函数,并创建新列  
closest_matches, similarities = find_closest_matches(non_empty_source_texts, non_empty_target_texts)  

#创建一个新的DataFrame来存储匹配结果  
results_df = pd.DataFrame({  
    closest_match_column: closest_matches,  
    similarity_column: similarities  
})  

#将结果DataFrame与原始DataFrame合并,只针对非空源文本  
#使用一个临时列来帮助合并,这里我们使用源文本的索引  
df['temp_index'] = df.index  
results_df['temp_index'] = range(len(non_empty_source_texts))  
merged_df = pd.merge(df, results_df, on='temp_index', how='left')  

#删除临时列  
merged_df.drop(columns=['temp_index'], inplace=True)  

#将结果写回Excel文件  
merged_df.to_excel(file_path, index=False)  

print("相似度匹配完成,并已写入原文件。")




若有更好的处理方式,请大佬们赐教!

免费评分

参与人数 4吾爱币 +9 热心值 +4 收起 理由
苏紫方璇 + 7 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
xiaosanmeng + 1 + 1 我很赞同!
wy0 + 1 + 1 我很赞同!
cshadow + 1 用心讨论,共获提升!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

cshadow 发表于 2024-8-1 20:04
或许 可以 考虑  对 原始数据 进行分词,然后进行匹配;像    临安市支行   安陆市支行   匹配度 都有80了
yanxiaoguang 发表于 2024-8-1 16:01
lsbdx 发表于 2024-8-1 16:16
学习中,这个最大化相似度匹配的理念,有很多用处!Excel的唯一性匹配,局限太大了
HarckerG 发表于 2024-8-1 16:22
很好的东西~
 楼主| dommy 发表于 2024-8-1 20:34
cshadow 发表于 2024-8-1 20:04
或许 可以 考虑  对 原始数据 进行分词,然后进行匹配;像    临安市支行   安陆市支行   匹配度 都有80了

嗯,是的。但我现在还不会这个,再行研究研究
yoga2joker 发表于 2024-8-1 20:39
很好的东西
52woniu 发表于 2024-8-2 08:29
好东西哦,谢谢分享
xiaosanmeng 发表于 2024-8-2 08:51
学习学习!!!
1e3e 发表于 2024-8-2 09:01
谢谢python的相似度代码网上很少感谢你的分享
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-12-14 13:56

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表