当前位置: 首页 > news >正文

Python 使用pandas库实现Excel字典码表对照自动化处理

效果演示

对照前(紊乱数据)

对照后(一一对应)

Python代码示例

# !/usr/bin/env python
# -*- coding:utf-8 -*-
"""
Creator: wcw
Date: 2025/7/29
Description: 字典对照自动化处理
"""
import os
import pandas as pdclass PDExcel(object):def __init__(self):pass@classmethoddef compa_excel(cls, dir_path, file_name, fillna_code="", fillna_name=""):"""将未对照的Excel数据进行对照处理,将结果输出到新的sheet中:param file_name:Excel文件名:param fillna_code:空值编码默认值:param fillna_name:空值名称默认值:return:"""# 读取Excel表数据print("开始读取Excel文件...")file_path = os.path.join(dir_path, file_name)sheet_data = pd.read_excel(io=file_path,sheet_name="SheetJS (2)",header=0,skiprows=0,dtype=str)print("读取Excel文件完成.")# 分别提取HIS字典和第三方字典内容his_data = sheet_data.loc[:, ["字典名称", "字典描述", "HIS字典代码", "HIS字典描述"]]vender_data = sheet_data.loc[:, ["第三方字典代码", "第三方字典描述"]]# print(his_data.at[0, "HIS字典代码"])# print(vender_data.get("第三方字典代码"))# 初始化对照前的字典数据columns = ["字典名称", "字典描述", "HIS字典代码", "HIS字典描述", "第三方字典代码", "第三方字典描述"]new_df = pd.DataFrame(data=None, columns=columns, dtype=str)new_df = pd.concat([new_df, his_data])# print(new_df)# 检索判断、对照处理print("处理对照中,请耐心等待...")for new_row in new_df.itertuples():# print(new_row)for vender_row in vender_data.itertuples():# if new_row.HIS字典描述 == vender_row.第三方字典描述:     # 精准匹配if str(new_row.HIS字典描述).find(str(vender_row.第三方字典描述)) != -1:    # 模糊匹配new_df.at[new_row.Index, "第三方字典代码"] = vender_row.第三方字典代码new_df.at[new_row.Index, "第三方字典描述"] = vender_row.第三方字典描述if pd.isna(new_df.at[new_row.Index, "HIS字典代码"]):new_df.drop(index=new_row.Index, inplace=True)  # inplace=True,修改原数据# 处理对照失败的默认值new_df.fillna({"第三方字典代码": fillna_code, "第三方字典描述": fillna_name}, inplace=True)# 得到对照后的字典数据print(new_df)print("处理对照完成.")# 修改原Excel数据print("开始输出到Excel...")new_df = new_df.astype(str)     # 指定数据类型,防止Excel自动转换# 使用ExcelWriter,可以在原Excel中新增sheet表,if_sheet_exists若sheet表存在的处理方式(overlay:直接覆盖内容保留原格式,replace:直接替换同名工作表‌‌)with pd.ExcelWriter(file_path, engine='openpyxl', mode='a', if_sheet_exists="overlay") as writer:new_df.to_excel(writer, sheet_name="SheetJS", columns=columns, index=False)  # index 是否写入行索引print("输出到Excel完成.")if __name__ == '__main__':# 运行方法print("程序已启动...")dir_path = r"D:\PythonDemo\字典手工对照"file_name = "7 微ESB字典手工对照-家庭关系代码表.xlsx"fillna_code = "99"fillna_name = "非亲属"PDExcel.compa_excel(dir_path, file_name, fillna_code, fillna_name)print("程序结束.")

 此毕。转载请注明出处。

http://www.xdnf.cn/news/1215919.html

相关文章:

  • macOS安装配置Unbound DNS完整指南
  • 学习日志22 python
  • docker 安装elasticsearch
  • QT笔记--》QMenu
  • CSS 工作原理
  • Java 笔记 封装(Encapsulation)
  • [硬件电路-106]:模拟电路 - 电路为什么会出现不同的频率特性?元件频率依赖性、信号传输路径、电路拓扑结构、外部因素
  • 微信小程序中实现页面跳转的方法
  • MySQL的单行函数:
  • C++ 中 NULL 与 nullptr 有什么区别?
  • rsync+sersync实现文件实时同步
  • Spark的宽窄依赖
  • 第七章:进入Redis的SET核心
  • 重生之我在暑假学习微服务第五天《Docker部署项目篇》
  • 【人工智能99问】混合专家模型(MoE)是如何训练的?(18/99)
  • pytorch小记(三十三):PyTorch 使用 TensorBoard 可视化训练过程(含完整示例)
  • LLM—— 基于 MCP 协议(SSE 模式)的工具调用实践
  • 30道JS高频经典笔试题集合+详解(一)
  • 华为昇腾×绿算全闪存缓存释放澎湃潜能
  • 【LeetCode】链表反转实现与测试
  • 比特币挖矿的能源消耗和环保问题
  • 关于“LoggerFactory is not a Logback LoggerContext but Logback is on ......“的解决方案
  • C++代码题部分(1)
  • LLM 模型部署难题的技术突破:从轻量化到分布式推理的全栈解决方案
  • AutoSAR(MCAL) --- ADC
  • Linux虚拟内存
  • 【C#】DevExpress.XtraEditors.MemoEdit memoEditLog控件讲解
  • AI服务器中,EEPROM有哪些部件使用,需要存储哪些信息?
  • Syzkaller实战教程2:运行环境配置+实例运行
  • 在Trae中使用MoonBit月兔