Python小实验——读&写Excel文件内容
安装xlrd模块和xlwt模块
读取Excel文件了内容需要额外的模块—— \(xlrd\),在官网上可以找到下载:https://pypi.python.org/pypi/xlrd#downloads。
下载完毕后解压到当前文件夹,点击进入,可以找到一个 setup.py 文件,在当前目录下打开 cmd 窗口,运行“python setup.py install”(需要提前将python添加环境变量),成功后,去Python Shell中运行“import xlrd”试一下,应该没什么问题。解压得到的xlrd模块文件都可以删除。
另外,如果你使用PyCharm的话,那就更好办了,点击"File" -> "Settings" -> "Project interpreter" -> "+" -> 查找"xlrd" -> "install package",OK了。
同样的,写入Excel文件需要的是 \(xlwt\) 模块,方法类似,就不多解释了。下载地址:https://pypi.python.org/pypi/xlwt。
读取Excel文件
不得不说,这个模块简单易懂,容易上手,几分钟就会了。直接看代码如何使用吧!
class myExcel(object):
def __init__(self, excelPath):
self.path = excelPath
def readExcel(self):
excel = xlrd.open_workbook(self.path)
# get sheet names
print(excel.sheet_names())
# get sheet content(By index or By name)
sheet = excel.sheet_by_index(0)
sheet1 = excel.sheet_by_name("Sheet1")
sheet2 = excel.sheets()[0]
# get sheet info
print(sheet.name, sheet.nrows, sheet.ncols)
# get row/col content
row = sheet.row_values(0)
col = sheet.col_values(0)
print(row, col)
# get cell value
cell = sheet.cell(0, 0)
print(cell.value)
print(sheet.cell_value(0, 0))
print(sheet.row(0)[0].value)
# get cell ctype:0empty 1string 2number 3date 4boolean 5error
print(sheet.cell(0, 0).ctype)
return excel
def printExcel(self):
excel = self.readExcel()
sheet = excel.sheets()[0]
for i in range(0, sheet.nrows):
row = sheet.row_values(i)
for item in row:
print(item, '|')
写入Excel文件
这个也还行,单纯的加入数据还是挺简单的。
发现了一个问题,这个xlwt模块只能保存为".xls"表格,有点绝望。
稍微查了一下,果然存在可以保存为".xlsx"表格的模块,叫做 \(openpyxl\),请参考:https://www.cnblogs.com/anpengapple/p/6399304.html?utm_source=itdadao&utm_medium=referral
def writeOneRow(self, sheet, nrow, rowList):
# 格式:{单元格:背景黄色;字体:红色粗体}
style = xlwt.easyxf('pattern: pattern solid, fore_colour yellow;font: bold 0, color red;')
ncol = 0
for row in rowList:
sheet.write(nrow, ncol, row, style)
ncol += 1
def writeExcel(self, excelName):
# create a Excel and add sheet
excel = xlwt.Workbook()
sheet = excel.add_sheet('sheet1', cell_overwrite_ok=True)
headList = ['Stu_id', 'name', 'sex']
data = [['1', 'stu1', '男'],
['2', 'stu2', '男'],
['3', 'stu3', '女'],]
self.writeOneRow(sheet, 0, headList)
for nrow in range(0, 3):
self.writeOneRow(sheet, nrow, data[nrow])
excel.save(excelName)
Excel转换成Markdown格式
其实这是我做这个小练习的主要原因,由于随笔都是用Markdowm格式写的,有一篇随笔是LeetCode所有题目的列表:
LeetCode All in One题解汇总(持续更新中...)。我才不想一条一条加呢!稍微转换一下,添加点格式符号就OK了。
def toMarkdown(self, mdName):
excel = self.readExcel()
sheet = excel.sheets()[0]
file = open(mdName, 'w', encoding='utf-8')
rowStr = "| %d | [%s]() | %.3f | '%s' |\n"
try:
file.write('| 编号 | 题名 | 过题率 | 难度 |' + '\n')
file.write('| :------------: |:---------------: | :------------:| :-----:|' + '\n')
for i in range(0, sheet.nrows):
row = sheet.row_values(i)
data = rowStr % (int(row[0]), str(row[1]), float(row[2]), str(row[3]))
file.write(data)
print('成功写入文件,共有%d条记录...' % sheet.nrows)
except Exception as e:
print(e)
finally:
file.close()
完整代码:https://github.com/Pacsiy/learnPY/tree/master/LeetCodeAllProblem
本文版权归作者AlvinZH和博客园所有,欢迎转载和商用,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.
Python小实验——读&写Excel文件内容的更多相关文章
- openpyxl -用于读/写Excel 2010 XLSX/XLSM文件的python库
openpyxl -用于读/写Excel 2010 XLSX/XLSM文件的python库¶ https://www.osgeo.cn/openpyxl/index.html
- 使用Python xlwt写excel文件
如果需要使用Python写Excel文件,首先下载或者安装xlwt. pip install xlwt 下面的这些demo应该可以帮助开发者快速上手使用xlwt写Excel文件: 创建工作簿(work ...
- Pandas 基础(4) - 读/写 Excel 和 CSV 文件
这一节将分别介绍读/写 Excel 和 CSV 文件的各种方式: - 读入 CSV 文件 首先是准备一个 csv 文件, 这里我用的是 stock_data.csv, 文件我已上传, 大家可以直接下载 ...
- 第15.25节 PyQt(Python+Qt)入门学习:Model/View开发实战--使用QTableView展示Excel文件内容
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 一.概述 在前面的订阅专栏<第十九章.Model/View开发:QTableView的功能及属 ...
- 基于Python的接口自动化-读写excel文件
引言 使用python进行接口测试时常常需要接口用例测试数据.断言接口功能.验证接口响应状态等,如果大量的接口测试用例脚本都将接口测试用例数据写在脚本文件中,这样写出来整个接口测试用例脚本代码将看起来 ...
- Java使用jxl.jar包写Excel文件的最适合列宽问题基本实现
以前用jxl.jar包,读写过Excel文件.也没有注意最适合列宽的问题,但是jxl.jar没有提供最适合列宽的功能,上次用到写了一下,可以基本实现最适合列宽. 注意,这个只是基本可以实现,基本针对中 ...
- 用Python的pandas框架操作Excel文件中的数据教程
用Python的pandas框架操作Excel文件中的数据教程 本文的目的,是向您展示如何使用pandas 来执行一些常见的Excel任务.有些例子比较琐碎,但我觉得展示这些简单的东西与那些你可以在其 ...
- JXL包大解析;Java程序生成excel文件和解析excel文件内容
最近需求变化,需要把excel导入 我以前没有做过,所以我查了一些资料 和参考别人的代码 以下是多种方式: import java.io.File; import java.io.FileInputS ...
- java对excel文件内容读写修改操作
Read.java package domain; import java.io.FileInputStream; import java.io.InputStream; import jxl.Cel ...
随机推荐
- mybatis调用存储过程获得取返回值
总体思路:map传值 controller: Map<String,Object> m=new HashMap<String,Object>(); m.put("na ...
- 如何求数字n的因数个数及因数和
我们有可能在某些数学题中会求到某个数的因数和,那我们怎么求呢? 因为我们知道任意一个合数都可以由两个或多个质数相乘得到,那么我们就先分解质因数吧 例:我们随便去一个数吧,嗯,就108了,好算... 我 ...
- Ckeditor 中粘贴图片
我们在ckeditor 中有上传图片,但是实际使用中这种手动上传图片方式并不是很方便,而是复制或者截图粘贴图片. 这里我们实现主要是获取对应的粘贴事件. CKEDITOR.instances[&quo ...
- Struts+Spring+Hibernate整合
这段笔记三两年前写的,一直因为一些琐事,或者搞忘记了,没有发.今天偶然翻出了它,就和大家一起分享下吧. 1.导入jar包 Struts的jar包: Spring的jar包: Hibernate的jar ...
- 在盒子(2CCC)的日子
在盒子(2CCC)的日子 DELPHIER的足迹印在DFW,印在2CCC.曾经的DFW和2CCC,学术气氛非常浓烈.有人提问,众人纷纷热心解答,仿佛是在解答自己难题.大家只为技术争的面红耳赤.很怀念当 ...
- ASP.NET Core2集成Office Online Server(OWAS)实现办公文档的在线预览与编辑(支持word\excel\ppt\pdf等格式)
Office Online Server是微软开发的一套基于Office实现在线文档预览编辑的技术框架(支持当前主流的浏览器,且浏览器上无需安装任何插件,支持word.excel.ppt.pdf等文档 ...
- How to extract msu/msp/msi/exe files from the command line
http://www.windowswiki.info/2009/02/19/how-to-extract-msumspmsiexe-files-from-the-command-line/ Micr ...
- TSQL--验证身份证是否有效
/****** Object: UserDefinedFunction [dbo].[udf_IsvalidIDCard] Script Date: 02/27/2014 16:03:20 ***** ...
- 【cocos2d-x 手游研发小技巧(3)Android界面分辨率适配方案】
先感叹一下吧~~android的各种分辨率各种适配虐我千百遍,每次新项目我依旧待它如初恋···· 每家公司都有自己项目工程适配的方案,这种东西就是没有最好,只有最适合!!! 这次新项目专项针对andr ...
- Dapper.Contrib.Extensions问题
Dapper.Contrib.Extensions问题 Dapper.Extension.1.0.0.1\lib\net45\Dapper.Extension.dll Dapper.Contrib.1 ...