百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

测开不得不会的python之xlrd库读取excel表内容

off999 2024-09-20 22:42 14 浏览 0 评论

学习目录

了解下电脑中的excel表格文件格式

安装xlrd库

xlrd库读取表格内容

1 先准备一个表格‘表格.xls’,表格中包含两个sheet页

2 导入xlrd库

3 用一个图展示下xlrd常用的函数

4 分别展示下表格中按行/按列/按单元格获取的内容

5 拓展内容

excel表格是大家经常用到的文件格式,各行各业都会跟它打交道。本次我们介绍经常用到的两个经典库,xlrd和xlwt,xlrd用于读取excel表格内容,xlwt用于写入excel表格内容。

了解下电脑中的excel表格文件格式

微软或者金山的excel表格编辑保存时一般要选择文件后缀,有xls和xlsx两类。

xls和xlsx后缀文件的主要区别:

  • 文件格式:xls是二进制格式,而xlsx是基于XML的压缩方式。
  • 版本:xls是Excel 2003及以前版本生成的文件格式,而xlsx是Excel 2007及以后版本生成的文件格式。
  • 兼容性:xlsx格式向下兼容,而xls格式不支持向后兼容。

安装xlrd库

pip install xlrd -i https://mirrors.aliyun.com/pypi/simple/

xlrd库默认安装最新的库,新版本的xlrd只支持.xls文件,如果需要读取.xlsx文件时需要安装旧版本(比如指定版本xlrd==1.2.0)。

xlrd库读取表格内容

1 先准备一个表格‘表格.xls’,表格中包含两个sheet页。

2 导入xlrd库

执行import xlrd导入该库

3 用一个图展示下xlrd常用的函数

4 分别展示下表格中按行/按列/按单元格获取的内容

  1. 按行获取内容
  • 获取总行数
#打开表格
data = xlrd.open_workbook('表格.xls')
#获取sheet1的内容
sheet1 = data.sheets()[0]
#行数
sheet1_nrows = sheet1.nrows
print(f'sheet1 行数:{sheet1_nrows}')
#结果
sheet1 行数:4
  • row()函数获取的内容
for i in range(sheet1_nrows):
  sheet1_row_content = sheet1.row(i)
  print(f'sheet1 第{i+1}行内容:{sheet1_row_content}')

#结果:
sheet1 第1行内容:[text:'user', text:'age']
sheet1 第2行内容:[text:'lili', number:21.0]
sheet1 第3行内容:[text:'zhangsan', number:13.0]
sheet1 第4行内容:[text:'lisi', number:35.0]
  • row_values()函数获取的内容
for i in range(sheet1_nrows):
  sheet1_row_content = sheet1.row_values(i)
  print(f'sheet1 第{i+1}行内容:{sheet1_row_content}')
#结果
sheet1 第1行内容:['user', 'age']
sheet1 第2行内容:['lili', 21.0]
sheet1 第3行内容:['zhangsan', 13.0]
sheet1 第4行内容:['lisi', 35.0]
  • get_rows()函数返回一个生成器,也是可迭代对象
for i in sheet1.get_rows():
  print(f'sheet1 中的行内容:{i}')
#结果:
sheet1 中的行内容:[text:'user', text:'age']
sheet1 中的行内容:[text:'lili', number:21.0]
sheet1 中的行内容:[text:'zhangsan', number:13.0]
sheet1 中的行内容:[text:'lisi', number:35.0]

2 按列获取内容

  • 获取总列数
sheet1_ncols = sheet1.ncols
print(f'sheet1 列数:{sheet1_ncols}')
  • col()函数获取的内容
for i in range(sheet1_ncols):
  sheet1_col_content = sheet1.col(i)
  print(f'sheet1 第{i+1}列内容:{sheet1_col_content}')
#结果:
sheet1 第1列内容:[text:'user', text:'lili', text:'zhangsan', text:'lisi']
sheet1 第2列内容:[text:'age', number:21.0, number:13.0, number:35.0]
  • col_values()函数获取的内容
for i in range(sheet1_ncols):
  sheet1_col_content = sheet1.col_values(i)
  print(f'sheet1 第{i+1}列内容:{sheet1_col_content}')
#结果
sheet1 第1列内容:['user', 'lili', 'zhangsan', 'lisi']
sheet1 第2列内容:['age', 21.0, 13.0, 35.0]

3 按单元格获取内容

print(f'sheet1 第1行 第2列内容:{sheet1.cell(0, 1).value}')
print(f'sheet1 第2行 第2列内容:{sheet1.cell_value(1, 1)}')
print(f'sheet1 第1行 第1列内容:{sheet1.row(0)[0].value}')
#结果:
sheet1 第1行 第2列内容:age
sheet1 第2行 第2列内容:21.0
sheet1 第1行 第1列内容:user

5 拓展内容

1)表格中数据类型介绍

0 - empty, 1 - text, 2 - number, 3 - date, 4 - boolean, 5 - error

表格sheet3中有如下内容:

获取数据类型如下:

sheet3 = data.sheets()[2]

row_type = sheet3.row_types(0)
print(row_type)

col_type = sheet3.col_types(1)
print(col_type)

cell_type = sheet3.cell_type(0,3)
print(cell_type)

#结果:
array('B', [0, 1, 2, 3, 4, 1])
[1]
3

2 获取行内容时发现填写的2023年10月8日返回的是数字

cell_content = sheet3.cell(0,3).value
print(cell_content)
#结果:
45207.0

原来excel表中的日期会被python根据一个时间基准计算出相差的的天数(1900-01-01和1904-01-01基准)

解决方法:使用xlrd.xldate.xldate_as_datetime函数处理得到的数字,它会返回datetime对象,用strftime把它转化成指定格式的字符串。

print(xlrd.xldate.xldate_as_datetime(cell_content,0).strftime("%Y/%m/%d"))
结果:2023/10/08


----感谢读者的阅读和学习,谢谢大家。


共勉: 东汉·班固《汉书·枚乘传》:“泰山之管穿石,单极之绠断干。水非石之钻,索非木之锯,渐靡使之然也。”

-----指水滴不断地滴,可以滴穿石头;

-----比喻坚持不懈,集细微的力量也能成就难能的功劳。

相关推荐

每天一个 Python 库:datetime 模块全攻略,时间操作太丝滑!

在日常开发中,时间处理是绕不开的一块,比如:生成时间戳比较两个时间差转换为可读格式接口传参/前端展示/日志记录今天我们就用一个案例+代码+思维导图,带你完全搞定datetime模块的用法!...

字节跳动!2023全套Python入门笔记合集

学完python出来,已经工作3年啦,最近有很多小伙伴问我,学习python有什么用其实能做的有很多可以提高工作效率增强逻辑思维还能做爬虫网站数据分析等等!!最近也是整理了很多适合零基...

为什么你觉得Matplotlib用起来困难?因为你还没看过这个思维导图

前言Matplotlib是一个流行的Python库,可以很容易地用于创建数据可视化。然而,设置数据、参数、图形和绘图在每次执行新项目时都可能变得非常混乱和繁琐。而且由于应用不同,我们不知道选择哪一个图...

Python新手必看!30分钟搞懂break/continue(附5个实战案例)

一、跳转语句的使命当程序需要提前结束循环或跳过特定迭代时,break和continue就是你的代码急刹按钮和跳步指令。就像在迷宫探险中:break=发现出口立即离开continue=跳过陷阱继续前进二...

刘心向学(24)Python中的数据类(python中5种简单的数据类型)

分享兴趣,传播快乐,增长见闻,留下美好!亲爱的您,这里是LearningYard新学苑。今天小编为大家带来文章“刘心向学(24)Python中的数据类”欢迎您的访问。Shareinterest,...

刘心向学(25)Python中的虚拟环境(python虚拟环境安装和配置)

分享兴趣,传播快乐,增长见闻,留下美好!亲爱的您,这里是LearningYard新学苑。今天小编为大家带来文章“刘心向学(25)Python中的虚拟环境”欢迎您的访问。Shareinte...

栋察宇宙(八):Python 中的 wordcloud 库学习介绍

分享乐趣,传播快乐,增长见识,留下美好。亲爱的您,这里是LearingYard学苑!今天小编为大家带来“Python中的wordcloud库学习介绍”欢迎您的访问!Sharethefun,...

AI在用|ChatGPT、Claude 3助攻,1分钟GET高颜值思维导图

机器之能报道编辑:Cardinal以大模型、AIGC为代表的人工智能浪潮已经在悄然改变着我们生活及工作方式,但绝大部分人依然不知道该如何使用。因此,我们推出了「AI在用」专栏,通过直观、有趣且简洁的人...

使用DeepSeek + Python开发AI思维导图应用,非常强!

最近基于Deepseek+PythonWeb技术开发了一个AI对话自动生成思维导图的应用,用来展示下如何基于低门槛的Python相关技术栈,高效结合deepseek实现从应用场景到实际应用的快速落地...

10幅思维导图告诉你 - Python 核心知识体系

首先,按顺序依次展示了以下内容的一系列思维导图:基础知识,数据类型(数字,字符串,列表,元组,字典,集合),条件&循环,文件对象,错误&异常,函数,模块,面向对象编程;接着,结合这些思维导图主要参考的...

Python基础核心思维导图,让你轻松入门

Python基础核心思维导图【高清图文末获取】学习路线图就给大家看到这里了,需要的小伙伴下方获取获取方式看下方图片...

Python基础核心思维导图,学会事半功倍

Python基础核心思维导图【高清图文末获取】学习路线图就给大家看到这里了,需要的小伙伴下方获取获取方式看下方图片...

硬核!288页Python核心知识笔记(附思维导图,建议收藏)

今天就给大家分享一份288页Python核心知识笔记,相较于部分朋友乱糟糟的笔记,这份笔记更够系统地总结相关知识,巩固Python知识体系。文末获取完整版PDF该笔记学习思维导图:目录内容展示【领取方...

Python学习知识思维导图(高效学习)

Python学习知识思维导图python基础知识python数据类型条件循环列表元组字典集合字符串序列函数面向对象编程模块错误异常文件对象#python##python自学##编程#...

别找了!288页Python核心知识笔记(附思维导图,建议收藏)

今天就给大家分享一份288页Python核心知识笔记,相较于部分朋友乱糟糟的笔记,这份笔记更够系统地总结相关知识,巩固Python知识体系。文末获取完整版PDF该笔记学习思维导图:目录内容展示【领取方...

取消回复欢迎 发表评论: