手把手教你用Python实现Excel中的Vlookup功能
liuian 2025-03-10 18:11 5 浏览
来源:Python爬虫与数据挖掘
作者:崔艳飞
一、前言
大家好,我是崔艳飞。工作中经常会遇到,需要把两张Excel或Csv数据表通过关键字段进行关联,匹配对应数据的情况,Excel虽有Vlookup函数可以处理,但数据量大时容易计算机无响应,可能出现数据丢失,处理速度较慢是软肋,而Python只需几行代码就能轻松实现,且处理速度快,详细如下。
二、项目目标
用Python实现两张Excel或Csv表数据关联处理。
三、项目准备
软件:PyCharm
需要的库:pandas
四、项目分析
1)如何读取要处理的Csv文件?
利用pandas库读取Csv文件。
2)如何读取要处理的Excel文件?
利用pandas库读取Excel文件。
3)如何通过关键字段关联匹配两张表中的数据?
利用merge()函数,通过关键字段,关联组合两张表中的数据。
4)如何保存结果?
利用to_csvl保存关联组合后的数据。
五、项目实现
1、第一步导入需要的库
import pandas as pd
2、第二步读取要处理的Csv文件
# 读入表1
df1 = pd.read_csv('D:/a/1.csv', encoding='gbk')
3、第三步读取要处理的Excel文件
# 读入表2
df2 = pd.read_excel('D:/a/2.xlsx', encoding='utf-8')
4、第四步关联匹配数据,并保存结果文件
# 关联数据
data = df1.merge(df2, on='姓名',left_index=False, right_index=False, sort=False)
# 保存数据
data.to_csv('D:/a/result.csv', encoding='gbk',index=False)
六、效果展示
1、处理前表1数据:
2、处理前表2数据:
3、处理后的关联匹配数据:
七、总结
本文介绍了如何利用Python进行Excel和Csv间的数据关联处理,替代了Excel的Vlookup函数,由于不用显示源文件,节省了系统资源,处理效率更高,数据量越大,优势越明显,Python还有很多类似的函数,数据处理,唯快不破,有兴趣的同学可以研究下,有问题随时留言,一起讨论学习。
相关推荐
- SQL Server数据库常用命令(建议收藏)
-
创建数据库:命令:createdatabase数据库名;示例:createdatabasestudent;删除数据库:命令:dropdatabase数据库名;示例:dropdatabas...
- SQL 语句大全
-
一、基础1、说明:创建数据库CREATEDATABASEdatabase-name2、说明:删除数据库dropdatabasedbname3、说明:备份sqlserver---创建备份数...
- SQL执行顺序(SqlServer)
-
学习SQL这么久,如果突然有人问你SQL的执行顺是怎么样的?是不是很多人会觉得C#、JavaScript都是根据编程顺序来处理的,那么SQL也是根据编程顺序来执行的吗?No.SQL不同于其它编程语言...
- SQL SERVER中的group by 分组查询和having字句
-
一、groupby分组查询1、已知如下数据:2、用groupby进行分组统计根据某一列分组,同时统计多种信息3、下列这种情况是错误的:4、那么要使上诉查询成立,就必须在groupby后...
- 聊一聊SQL Server中的Row_Number
-
排序函数提供了一个非常好的特性,即在SQL中为结果集中的记录分配编号。SQL中的Row_Number是其中一个函数,它允许我们为结果集数据的行分配排名或编号。根据使用的排序函数的类型,将不同的值分配给...
- NodeJs安装和环境配置(Windows安装包方式)
-
1、官网下载https://nodejs.org/en/download/根据自己电脑系统及位数选择,我的电脑是Windows系统、64位、想下载稳定版的.msi(LTS为长期稳定版)这里选择wind...
- 与 AI 的斗智斗勇:从 npm 到 pnpm 的迁移之旅(AI 润色后的内容)
-
与AI的斗智斗勇:从npm到pnpm的迁移之旅最近听说pnpm是个好东西,能节约内存资源,简直是程序员的福音。于是我心血来潮,决定把当前项目的包管理工具从npm改成pnpm。毕竟...
- 2021 年 Node.js 开发人员学习路线图
-
Node.js自发布以来,已成为业界重要破局者之一。Uber、Medium、PayPal和沃尔玛等大型企业,纷纷将技术栈转向Node.js。Node.js支持开发功能强大的应用,例如实时追踪...
- 零基础小白也能学会!手把手教你用Electron打包网页为桌面应用
-
一、引言Electron是一款由GitHub开发的开源框架,允许开发者使用HTML、CSS和JavaScript构建跨平台的桌面应用程序。无论你是Web开发者,还是想将现有网页项目转...
- 在 Windows上安装 Node.js 开发环境的完整指南
-
在Windows上安装Node.js开发环境的完整指南一、安装Node.js和npm下载Node.js安装包访问官网Node.js—在任何地方运行JavaScript下载...
- 带你一步步搭建一个 Node.js 服务器
-
爱学习的小伙伴们,Node.js服务器有听说过没,是否觉得陌生?如此,就一起动手搭建一个吧。会的小伙伴可以略过哟~以下是搭建Node.js服务器的详细步骤:1.安装Node.js和npm...
- 小白都看得懂的Vue3.0语法教程-01-框架搭建
-
开发环境编辑器推荐:VisualStudioCode+Volar扩展检查node:vue3.0推荐node16以上node-v//查看node版本号npm-v//查看npm版本...
- pc端微信用户图片DAT格式解码为图片
-
电脑越来越慢,发现硬盘空间被大量占用,发现是微信自己账号下的Image文件夹引起的,因不清楚里面的图片有些是否有用,想清理一下。会代码的朋友可以看一下代码,自己做一下。不会代码的朋友可以看一下最后的结...
- 微信小程序分享功能
-
由于小程序的分享(微信、头条平台),需要监听页面的onShareAppMessage生命周期,小程序需要在页面声明了此生命周期,点击右上角的"胶囊"才会有分享功能,而一般情况下,我们希...
- SpringBoot+Uniapp实战开发全新仿抖音短视频App(完结)
-
历经实战检验的千万级流量架构:SpringBoot微服务集群支撑日活百万用户,Uniapp跨端方案实现秒级视频发布,智能推荐算法200毫秒内精准响应,多级缓存与混合存储体系保障99.99%高可用性,M...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
《人人译客》如何规划你的移动电商网站(2)
-
Jupyterhub安装教程 jupyter怎么安装包
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- react-admin (33)
- vscode切换git分支 (35)
- vscode美化代码 (33)
- python bytes转16进制 (35)