Python如何使用xlrd和xlwt库读写excel文件
作者:AllardZhao
这篇文章主要介绍了Python如何使用xlrd和xlwt库读写excel文件问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
如何读写excel文件?
实际案例
Microsoft Excel是日常办公中使用最频繁的软件,其数据格式为xls,xlsx,一种非常常用的电子表格。
小学某班成绩,记录在excel文件中:
姓名 语文 数学 外语 李雷 95 99 96 韩梅 98 100 93 张峰 94 95 95 .... ....
利用python读写excel,添加"总分"列,计算每人总分。
解决方案
使用pip3安装:$ pip3 install xlrd xlwt
使用第三方库xlrd和xlwt,这两个库分别用于excel读reader(rd)和写writer(wt) 。
注意:
[1] xlrd 2.1.0最新版本是不支持xlsx文件,可以创建xls文件复制之前内容粘贴,或者卸载现在版本然后重新安装xlrd==1.1.0。
[2] excel文件格式类型为"Microsoft Excel 97-2003 文件(*.xls)"
代码演示
(1)excel文件的读xlrd和xlwt写使用
import xlrd # 读取excel,返回一个对象 book = xlrd.open_workbook('demo.xls') # 获取一个book当中所有的表,返回一个列表其中每一个项是sheet对象 print(book.sheets()[0]) # 还可以通过sheet_by_name或sheet_by_name得到表 sheet = book.sheet_by_index(0) print(sheet) # 获取一张表行数和列数 r_num = sheet.nrows c_num = sheet.ncols print(r_num, c_num) ''' 一个book可以包含许多的表(sheet),一张表是由一个个单元格构成, 一个单元格也就是一个cell。 ''' # 如果获取每一个cell(单元格)的对象,需要传入行列坐标 print(sheet.cell(0, 0)) print(sheet.cell(1, 1)) # 单元格中内容的类型,它是一个枚举值,可以通过xlrd.XL_CELL_[类型]查看枚举值对应类型 print(sheet.cell(0, 0).ctype) print(sheet.cell(1, 1).ctype) # 获取cell对象的值 print(sheet.cell(0, 0).value) print(sheet.cell(1, 1).value) # 一次性获取一行数据或一列数据,传入行号或列号 r1 = sheet.row(1) # 返回一个列表,其中每一个都是cell对象 print(r1) # 不想获取cell对象,只想获取其中值 print(sheet.row_values(1)) # 还可以类似于切片操作指定某一个列的范围 # 第1个参数为行号,第2个参数为起始列 print(sheet.row_values(1, 1)) # 为表添加单元格,参数:行值、列值、类型、内容、字体的对齐方式 # sheet.put_cell() # 写excel import xlwt # 创建excel,实例化一个workbook w_book = xlwt.Workbook() # 添加表 w_sheet = w_book.add_sheet('sheet1') # 为表添加单元格 w_sheet.write(0, 0) # 写入到文件中,输出文件的文件名 w_book.save('output.xls')
(2)实现excel文本的处理和保存
import xlrd, xlwt # 打开excel r_book = xlrd.open_workbook('demo.xls') # 得到第一张表 r_sheet = r_book.sheet_by_index(0) # 获得表的列数 nc = r_sheet.ncols # 向表中添加cell单元格,传入:行号,列号,类型 r_sheet.put_cell(0, nc, xlrd.XL_CELL_TEXT, '总分', None) # 迭代每一行计算总分 for row in range(1, r_sheet.nrows): # 跳过第1列,得到之后每个单元格内容列表求和 t = sum(r_sheet.row_values(row, 1)) # 添加一个cell单元格,存放每个学生的总分 r_sheet.put_cell(row, nc, xlrd.XL_CELL_NUMBER, t, None) # 写入到excel文件中 w_book = xlwt.Workbook() w_sheet = w_book.add_sheet(r_sheet.name) # 设置对齐方式,水平和垂直都居中 style = xlwt.easyxf('align: vertical center, horizontal center') # 将r_sheet单元格内容写到w_sheet当中 for r in range(r_sheet.nrows): for c in range(r_sheet.ncols): w_sheet.write(r, c, r_sheet.cell_value(r, c), style) # 保存内容 w_book.save('output.xls')
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。