Python编程快速上手——Excel到CSV的转换程序案例分析
作者:授我以驴 发布时间:2023-03-20 08:14:01
标签:Python,Excel,CSV,转换
本文实例讲述了Python Excel到CSV的转换程序。分享给大家供大家参考,具体如下:
题目如下:
利用第十二章的openpyxl模块,编程读取当前工作目录中的所有Excel文件,并输出为csv文件。
一个Excel文件可能包含多个工作表,必须为每个表创建一个CSV文件。CSV文件的文件名应该是<Excel 文件名>_<表标题>.csv,其中< Excel 文件名 >是没有拓展名的Excel文件名,<表标题>是Worksheet对象的title变量中的字符串
该程序包含许多嵌套的for循环。该程序框架看起来像这样:
for excelFile in os.listdir('.'):
# skip non-xlsx files, load the workbook object
for sheetname in wb.get_sheet_names():
#Loop through every sheet in the workbook
sheet = wb.get_sheet_by_name(sheetname)
# create the csv filename from the Excel filename and sheet title
# create the csv.writer object for this csv file
#loop through every row in the sheet
for rowNum in range(1, sheet.max_row + 1):
rowData = [] #append each cell to this list
# loop through each cell in the row
for colNum in range (1, sheet.max_column + 1):
#Append each cell's data to rowData
# write the rowData list to CSV file
csvFile.close()
从htttp://nostarch.com/automatestuff/下载zip文件excelSpreadseets.zip,将这些电子表格压缩到程序所在目录中。可以使用这些文件来测试程序
思路如下:
基本上按照题目给定的框架进行代码的编写
对英文进行翻译,理解意思即可快速编写出程序
代码如下:
#! python3
import os, openpyxl, csv
for excelFile in os.listdir('.\\CSV'): #我将解压后的excel文件放入此文件夹
# 筛选出excel文件,创建工作表对象
if excelFile.endswith('.xlsx'):
wb = openpyxl.load_workbook('.\\CSV\\'+ excelFile)
for sheetName in wb.get_sheet_names():
#依次遍历工作簿中的工作表
sheet = wb.get_sheet_by_name(sheetName)
#根据excel文件名和工作表名创建csv文件名
#通过csv.writer创建csv file对象
basename = excelFile[0:-5] #将excel文件名进行切割,去掉文件名后缀.xlsx
File = open('{0}_{1}.csv'.format(basename,sheetName),'w') #新建csv file对象
csvFile = csv.writer(File) #创建writer对象
#csvFileWriter.writerow()
#遍历表中每行
for rowNum in range(1,sheet.max_row+1):
rowData = [] #防止每个单元格内容的列表
#遍历每行中的单元格
for colNum in range(1,sheet.max_column + 1):
#将每个单元格数据添加到rowData
rowData.append(sheet.cell(row = rowNum,column = colNum).value)
csvFile.writerow(rowData)
#将rowData列表写入到csv file
File.close()
运行结果:
希望本文所述对大家Python程序设计有所帮助。
来源:https://blog.csdn.net/one_Salted_FishGG/article/details/89502908


猜你喜欢
- 目录互斥机制写流程读流程恢复流程在Hadoop2.X之前,Namenode是HDFS集群中可能发生单点故障的节点,每个HDFS集群只有一个n
- 目录MySQL 主备的基本原理binlog 的三种格式对比为什么会有 mixed 格式的 binlog?循环复制问题总结:抛出问题:大家知道
- ceil()方法返回x的值上限 - 不小于x的最小整数。语法以下是ceil()方法的语法:import mathmath.cei
- 需求描述最近在写一个图像标注小工具,其中需要用到一个缩略图列表,来查看文件夹内的图片文件。这里整理一个基于QListWidget实现的版本,
- strconv包该包主要实现基本数据类型与其字符串表示的转换。常用函数为Atoi()、Itia()、parse系列、format系列、app
- 当使用for语句循环(迭代)pandas.DataFrame时,简单的使用for语句便可以取得返回列名,因此使用重复使用for方法,便可以获
- 效果图:图(1)初始图图(2)点击“从右侧划出”代码如下:<!DOCTYPE html><html> <hea
- 数据库开发数据库应用,选择一个好的数据库是非常重要的。下面从一些方面比较了SQL Server与Oracle、DB2三种数据库,为你选择数据
- 本文实例为大家分享了Python实现24点小游戏的具体代码,供大家参考,具体内容如下玩法:通过加减乘除操作,小学生都没问题的。源码分享:im
- 引言在观察MySQL本地连接的时候,发现对mysql.sock是个啥我不明白,于是我提出了一个问题:mysql.sock到底存了什么信息?根
- ACCESS有个BUG,那就是在使用 like 搜索时如果遇到日文就会出现“内存溢出”的问题,提示“80040e14/内
- 前言在pytorch中, 想删除tensor中的指定行列,原本以为有个函数或者直接把某一行赋值为[]就可以,结果发现没这么简单,因此用了一个
- 一、索引的优劣势优点:可以快速的检索 、可以加快分组和排序缺点: 占用储存空间、降低数据表的修改操作二、索引的分类主键索引即主索
- 用python给自己做个练习系统刷题吧!实现效果实现代码选择题def xuanze(): global flag2
- 给定一个字符串,要求在这个字符串中找到符合回文性质的最长子串。所谓回文性是指诸如 “aba”,"ababa","
- 很常见的一个图片轮播Flash,使用之后发现在IE下按F5刷新之后Flash区域就变成一大块背景色,内容轮播出不来了。有趣的是右键点击Fla
- Python安装流程:一.下载在网上(输入网址https://www.python.org/downloads/)下载Windows最新的p
- 其实网上已经有很多ASP生成htm的文章了,有一种方法是ASP+XML的生成方法,虽然有一种好处就是不用程序写模版就可以直接引用原来的要生成
- 当我想要完美的使用:nth-child或者:nth-of-type的时候有点儿头晕。你越理解它们,就能写出越好的CSS规则!在这些简单的”秘
- 通过上篇文章给大家介绍了SqlServer应用之sys.dm_os_waiting_tasks 引发的疑问(上) ,说了一下sys.dm_e