文件格式转换: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,一经查实,立即删除!

相关文章

P1439 【模板】最长公共子序列 (线性DP,LCS + LIS)

【模板】最长公共子序列 题目描述 给出 1 , 2 , … , n 1,2,\ldots,n 1,2,…,n 的两个排列 P 1 P_1 P1​ 和 P 2 P_2 P2​ ,求它们的最长公共子序列。 输入格式 第一行是一个数 n n n。 接下来两行,每行为 n n n 个数,为自然数 1 …

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 网络:连接互联网…

几种修改docker默认存储位置的方法

需求 docker容器存放目录磁盘空间满了,需要转移数据,修改Docker默认存储位置 解决方法 方法1:迁移到新目录 停止docker服务。 1systemctl stop docker; //每个liunx版本的命令不一样。创建新的docker目录,执行命令df…

为了有了ReentrantLock还需要ReentrantReadWriteLock?

ReentrantLock 和 ReentrantReadWriteLock 是 Java 中的两种不同实现的锁,它们各自适用于不同的应用场景。以下是为什么需要 ReentrantReadWriteLock 的几个原因: 1. 读写分离 ReentrantLock 是一种独占锁,适用于任何线程操作共享资源的场景…

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. 创建代码文件…

ARM/Linux嵌入式面经(三三):大疆

嵌入式工程师考察主要蕴含:C/C++,处理器的架构,操作系统(linux或嵌入式实时操作系统),常见硬件接口协议/总线,文件存储系统等几方面 文章目录 1)C/C++static作用,变量加入static以后在内存中存储位置的变化。static的作用变量加入static后在内存中存储位置的变化面试官…

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

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

详解QT元对象系统用法

文章目录 元枚举 QMetaEnum元方法 QMetaMethod元对象构建 QMetaObjectBuilder元属性 QMetaProperty定义元对象属性获取属性信息与信号和槽结合QML属性访问动态属性元类型 QMetaTypeQt的元对象系统是Qt框架中的一个核心特性,它为Qt应用程序提供了一种动态类型信息机制。这种机制…

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

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

解决 webpack 配置 sass-loader后报错,无法正常build

1. 问题描述 总是打包build报错,本质上css样式语法也没写错在使用 sass-resources-loader 的项目中,开发者常常遇到构建错误或意外的样式行为,这是因为 sass-resources-loader 的作用和使用场景并不总是被正确理解。sass-resources-loader 主…

【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与…

智能体趋势:未来科技的核心驱动力

随着人工智能(AI)技术的不断发展,**智能体(intelligent agents)**逐渐成为当今科技发展的重要趋势。这些智能体不仅仅是软件,它们正在改变我们生活和工作的方式,成为推动科技和社会变革的核心力…

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…

Go语言现代web开发defer 延迟执行

The defer statement will delay the execution of a function until the surrounding function is completed. Although execution is postponed, funciton arguments will be evaluated immediately. defer语句将延迟函数的执行,直到周围的函数完成。虽然执行被延…

SpringBoot用kafka.listener监听接受Kafka消息

1.创建kafka监听配置并进行注册 import org.apache.kafka.clients.consumer.ConsumerConfig; import org.apache.kafka.common.serialization.StringDeserializer; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation…

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

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