文件格式转换:EXCEL和CSV文件格式互相转换

目录

  • 1.EXCEl和CSV文件格式互相转换
    • 1.1首先安装所需的Python包
    • 1.2excel转换为csv代码如下:
    • 1.3csv转换为excel代码如下:

由于excel文件在数学建模数据处理当中的局限性,我们通常把excel文件转换为csv文件来处理,下面是相关的代码,我直接封装成函数,你们直接调用即可,我会添加详细的注释。

1.EXCEl和CSV文件格式互相转换

1.1首先安装所需的Python包

先激活自己创建的环境,不会的可以参考我这篇博文Python-Anaconda基础虚拟环境创建及激活.

激活环境以后,使用下述代码进行安装。

pip install pandas openpyxl

安装结果如下:
在这里插入图片描述

1.2excel转换为csv代码如下:

import os
import pandas as pddef excel_to_csv_all_sheets(excel_file_path, output_prefix=""):"""将Excel文件的所有工作表转换为CSV文件,保存在与Excel文件相同的目录中。参数:excel_file_path (str): Excel文件的路径output_prefix (str): 输出CSV文件的前缀(默认为空字符串)"""try:# 获取Excel文件所在的目录output_directory = os.path.dirname(excel_file_path)# 读取Excel文件中的所有工作表excel_data = pd.read_excel(excel_file_path, sheet_name=None)# 遍历每个工作表并将其转换为CSV文件for sheet_name, data in excel_data.items():# 如果指定了前缀,则使用前缀+工作表名称作为文件名,否则仅使用工作表名称csv_file_name = f"{output_prefix}{sheet_name}.csv"csv_file_path = os.path.join(output_directory, csv_file_name)data.to_csv(csv_file_path, index=False)print(f"成功将工作表 {sheet_name} 转换为CSV文件 {csv_file_path}")except Exception as e:print(f"转换失败: {e}")# 下面是相应的调用函数代码
excel_to_csv_all_sheets('eg_convert.xlsx', output_prefix="my_custom_name_")

代码使用说明:eg_convert.xlsx是你要转换的文件,你自己填写,my_custom_name_是转换后的文件名,比如说转换后为output.csv,那么你的my_custom_name_就写output。
注意它是将每个Sheet都单独转换出来,成为独立的csv文件。
注意my_custom_name_.csv不能已经存在,否则代码会报错。

在这里插入图片描述
代码运行过程:在这里插入图片描述

转换后的结果如下:

在这里插入图片描述

1.3csv转换为excel代码如下:

import os
import pandas as pddef csv_to_excel_separate_sheets(csv_file_paths, excel_file_path):"""将多个CSV文件转换为Excel文件中的单独工作表。参数:csv_file_paths (list of str): CSV文件的路径列表excel_file_path (str): 输出Excel文件的路径"""try:# 创建ExcelWriter对象以便写入Excel文件with pd.ExcelWriter(excel_file_path, engine='openpyxl') as writer:# 遍历每个CSV文件路径,将其读取并写入到Excel文件的单独工作表中for csv_file_path in csv_file_paths:df = pd.read_csv(csv_file_path)  # 读取CSV文件# 使用CSV文件名(去除扩展名)作为工作表名称sheet_name = os.path.basename(csv_file_path).replace('.csv', '')df.to_excel(writer, index=False, sheet_name=sheet_name)print(f"成功将CSV文件 {csv_file_path} 转换为Excel文件中的工作表 {sheet_name}")print(f"所有CSV文件已成功转换为Excel文件 {excel_file_path}")except Exception as e:print(f"转换失败: {e}")# 将多个CSV文件转换为一个Excel文件
csv_files = ['my_custom_name_Sheet1.csv', 'my_custom_name_Sheet2.csv']  # CSV文件列表
csv_to_excel_separate_sheets(csv_files, 'combined_output.xlsx')

代码使用说明:
很直观,my_custom_name_Sheet1.csvmy_custom_name_Sheet2.csv是需要转换的csv文件,combined_output.xlsx是合并后的文件,。
注意:my_custom_name_Sheet1.csvmy_custom_name_Sheet2.csv文件内部必须有数据,否则会报错,如果只有一个文件,调用格式如下:

如果只有一个csv文件需要转换,其调用格式如下:

csv_files = ['my_custom_name_Sheet1.csv']  # CSV文件列表
csv_to_excel_separate_sheets(csv_files, 'combined_output.xlsx')

代码运行过程:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/54001.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java算法总结

文章目录 一、链表相关1.1 从尾到头打印单链表[要求 方式1:反向遍历。方式2:Stack栈]1.2 josephu问题(使用带尾指针的循环链表) 二、动态规划2.1 斐波那契数列 2022.4.182.2 青蛙上台阶 2022.4.18 三、位运算符3.1 二进制中1的个数…

统信服务器操作系统【d版字符系统升级到dde图形化】配置方法

统信服务器操作系统d版本上由字符系统升级到 dde 桌面系统的过程 文章目录 一、准备环境二、功能描述安装步骤1. lightdm 安装2. dde 安装 一、准备环境 适用版本:■UOS服务器操作系统d版 适用架构:■ARM64、AMD64、MIPS64 网络:连接互联网…

kettle 数据库迁移 使用分页原理实现 数据库mysql

使用 kettle 9.0 先修改配置文件: C:\Users\xx\.kettle 新增如下配置,解决mysql 空字符串 自动转 null bug KETTLE_EMPTY_STRING_DIFFERS_FROM_NULLY git地址: GitHub - 2292011451/kettle_tool 第一步: 先把要迁移的表进行读取,循环查询每个表的最大数量以及页数,追加到…

linux文件系统权限详解

注:目录的执行权限代表是否可以进入。 一、文件权限控制对文件的访问: 可以针对文件所属用户、所属组和其他用户可以设置不同的权限 权限具有优先级。user权限覆盖group权限,后者覆盖other权限。 有三种权限类别:读取、写入和执行 读权限:对文件:可读取文件…

VS Code 配置 C/C++ 编程运行环境(保姆级教程)

文章目录 一、软件下载1. 下载 VS Code 安装工具 2. 下载 MinGW-W64二、安装 VS Code三、安装 MinGW-W64 及配置环境变量四、配置 VS Code 的 C/C 编程运行环境1. 汉化 VS Code(选做)2. 安装 C/C 扩展包 五、测试 VS Code 的 C/C 编程环境1. 创建代码文件…

hku-mars雷达相机时间同步方案-软件驱动(MID360与海康MV-CB060-10UMUC-S)

hku-mars雷达相机时间同步方案-软件驱动 hku的方案在硬件和软件方面都做了工作,所以才会实现相机帧和雷达帧的完全对齐。硬件方面的设置请参考上一期。 港大的同步结果: hku-mars雷达相机时间同步方案-硬件(MID360与海康MV-CB060-10UMUC-S&…

窗口嵌入桌面背景层(vb.net,高考倒计时特供版)

开发思路 根据系统生成高考倒计时的具体时间,附加江苏省省统考的时间生成算法,并且用户可以根据实际情况调整前后30天,具有丰富多彩的图片库和强大的自定义功能,效果图见P3 目前程序处于正式版的1.4版本,本程序由本作…

【HarmonyOS】鸿蒙头像上传-(编辑个人信息页- 头像上传)+实时数据更新

#效果图 #思路 ##步骤: ###一、利用picker api选择1张图片 实例化选择器参数(使用new PhotoSelectOptions())实例化图片选择器 (使用newPhotoViewPicker() )调用图片选择器的select方法传入选择器参数完成图片选取获得结果 利用picker api选择1张图片 async sele…

[Redis] Redis中的Hash类型和List类型

🌸个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 🏵️热门专栏: 🧊 Java基本语法(97平均质量分)https://blog.csdn.net/2301_80050796/category_12615970.html?spm1001.2014.3001.5482 🍕 Collection与…

eureka.client.service-url.defaultZone的坑

错误的配置 eureka: client: service-url: default-zone: http://192.168.100.10:8080/eureka正确的配置 eureka: client: service-url: defaultZone: http://192.168.100.10:8080/eureka根据错误日志堆栈打断电调试 出现两个key,也就是defaultZone不支持snake-c…

【PCB工艺】如何实现PCB板层间的互连

系列文章目录 1.元件基础 2.电路设计 3.PCB设计 4.元件焊接 5.板子调试 6.程序设计 7.算法学习 8.编写exe 9.检测标准 10.项目举例 11.职业规划 文章目录 前言①、什么是通孔②、通孔是怎样产生的③、通孔种类④、盘中孔⑤、设计建议 前言 送给大学毕业后找不到奋斗方向的你…

C++函数在库中的地址

本文讲述C如何直接调用动态库dll或者so中的函数。 首先我们准备一个被调用库,这个库里面有两个函数,分别是C98 与 C11 下的,名称是run2和run1。 被调用库 相关介绍请看之前的文章《函数指针与库之间的通信讲解》。 //dll_ex_im.h #ifndef…

OpenSSH9.8p1编译rpm包(建议收藏)

1.升级前的openssh版本 [root@ncayu8847 ~]# ssh -V OpenSSH_7.4p1, OpenSSL 1.0.2k-fips 26 Jan 20172.下载软件包(离线包) openssh 源码下载地址: https://mirrors.aliyun.com/pub/OpenBSD/OpenSSH/portable/openssl源码下载 https:/

JUC学习笔记(二)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 四、共享模型之内存4.1 Java 内存模型4.2 可见性退不出的循环解决方法可见性 vs 原子性模式之 Balking1.定义2.实现 4.3 有序性原理之指令级并行1. 名词2.鱼罐头的故…

关于手机号码数理的计算和推导,获得“平替”尾号

文章背景:我个人比较相信命运,对于手机号码的吉凶或是数理颇为在乎。最近,我沉浸于这方面的研究中,并发现许多手机号码的数理核心竟出奇地一致——关键在于后四位尾号,而前面的数字似乎并不占据主导位置。然而&#xf…

使用 GaLore 预训练LLaMA-7B

项目代码: https://github.com/jiaweizzhao/galorehttps://github.com/jiaweizzhao/galore 参考博客: https://zhuanlan.zhihu.com/p/686686751 创建环境 基础环境配置如下: 操作系统: CentOS 7CPUs: 单个节点具有 1TB 内存的 Intel CP…

【C++】入门基础(下)

Hi!很高兴见到你~ 目录 7、引用 7.3 引用的使用(实例) 7.4 const引用 【第一分点】 【第二分点1】 【第二分点2】 7.5 指针和引用的关系(面试点) 8、inline 9、nullptr Relaxing Time! ———…

Mysql(二) - 约束, 进阶查询

目录 一.约束 1.not null 2.unique 3.default 4.primary key 5. foreign key 6.check 7. 综合使用 二.进阶查询 1.新增(插入查询的结果) 2.聚合查询 a.聚合函数 b.使用 3.分组查询 4.联合查询 a.内连接 b.外连接 c.自连接 d.子查询 5.合并查询 三.总结 一…

基于SpringBoot的招生宣传管理系统【附源码】

基于SpringBoot的招生宣传管理系统(源码L文说明文档) 目录 4 系统设计 4.1 系统概述 4.2系统功能结构设计 4.3数据库设计 4.3.1数据库E-R图设计 4.3.2 数据库表结构设计 5 系统实现 5.1管理员功能介绍 5.1.1管理员登录 …

Ubuntu22.04系统安装opencv步骤简述及问题解决方法

前言 opencv是一个功能强大、开源且跨平台的计算机视觉库,适用于多种编程语言和操作系统,能够帮助开发者构建各种视觉项目。其模块众多,提供了诸多功能,能够进行图像处理、视频处理等等。比如:Highgui模块提供图像用户…