Python如何使用xlrd和xlwt库读写excel文件

 更新时间:2024年02月10日 09:44:03   作者: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')

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Python输出列表(list)的倒序/逆序的几种方法

    Python输出列表(list)的倒序/逆序的几种方法

    列表是一个有序的元素集合,而列表的倒序或逆序操作也是常见的需求之一,本文主要介绍了Python输出列表(list)的倒序/逆序的几种方法,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • Python中偏函数用法示例

    Python中偏函数用法示例

    这篇文章主要介绍了Python中偏函数用法,结合实例形式分析了Python基于functools模块创建和使用偏函数的相关操作技巧与注意事项,需要的朋友可以参考下
    2018-06-06
  • python设置代理和添加镜像源的方法

    python设置代理和添加镜像源的方法

    这篇文章主要介绍了python设置代理和添加镜像源介绍,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • Python基础教程之正则表达式基本语法以及re模块

    Python基础教程之正则表达式基本语法以及re模块

    正则表达式是可以匹配文本片段的模式,今天的Python就跟大家一起讨论一下python中的re模块,python re模块感兴趣的朋友一起学习吧
    2016-03-03
  • 10个Python自动化办公的脚本分享

    10个Python自动化办公的脚本分享

    在日常办公中,我们常常会被繁琐、重复的任务占据大量时间,本文为大家分享了10个实用的 Python 自动化办公案例及源码,希望对大家有所帮助
    2025-02-02
  • Django多对多ManyToManyField字段的使用

    Django多对多ManyToManyField字段的使用

    Django是一个支持多对多关系的Web框架,可以在模型中定义多对多关系,本文主要介绍了Django多对多ManyToManyField字段的使用,感兴趣的可以了解一下
    2023-12-12
  • Python实现批量将MP3音频转为WAV格式详解

    Python实现批量将MP3音频转为WAV格式详解

    这篇文章主要介绍了通过Python实现将MP3音频转为WAV格式的方法,文中的示例代码讲解详细,对我们学习Python有一定帮助,感兴趣的可以了解一下
    2021-12-12
  • Flask框架踩坑之ajax跨域请求实现

    Flask框架踩坑之ajax跨域请求实现

    这篇文章主要介绍了Flask框架踩坑之ajax跨域请求实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-02-02
  • 用Python一键搭建Http服务器的方法

    用Python一键搭建Http服务器的方法

    今天小编就为大家分享一篇用Python一键搭建Http服务器的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-06-06
  • 深入了解Python中Pytest Markers的使用方法

    深入了解Python中Pytest Markers的使用方法

    从这篇开始,逐一解决fixture是啥,mark是啥,参数request是啥,钩子函数是啥,parametrize参数化是啥,这些问题,本片先介绍一下mark是啥,以及如何使用
    2023-09-09

最新评论