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

Python自动化:xlrd读取excel

off999 2025-05-15 20:26 23 浏览 0 评论

# pip install xlrd

工作簿、工作表相关操作:

import xlrd
# 打开工作簿
people = xlrd.open_workbook('people1.xls') 
#xlrd只能打开.xls格式,不能打开.xlsx格式

# 打开.xlsx格式
# pip install xlrd3
# import xlrd3 as xlrd
# people1 = xlrd.open_workbook('people2.xlsx')

# 选择工作表
sheet = people.sheet_by_index(0)   #选择第一个工作表,并将其赋值给sheet
sheet2 = people.sheet_by_name('Sheet1')   #选择名为Sheet1 的工作表,并将其赋值给sheet2
sheet3 = people.sheets()[0]   #选择第一个工作表,并将其赋值给sheet3

#获取工作簿中工作表的数目
sheets_num = people.nsheets     
print(sheets_num)

#获取工作簿中工作表名称列表
sheets_names = people.sheet_names()   
print(sheets_names)

 #获取工作表中有值单元格的行数
nrows = sheet.nrows   
print(nrows)    #12

#获取工作表中有值单元格的列数
ncols = sheet.ncols     
print(ncols) # 5

行相关操作:

# sheet.row(rowx)  #获取由该行中所有的单元格对象组成的列表
print(sheet.row(2))    #打印出第3行所有单元格对象组成的列表
# [number:3.0, text:'c', text:'三', text:'他', xldate:45660.0],日期类型的数据打印出来不对

# sheet.row_values(rowx, start_colx=0, end_colx=None)  #返回由该行中所有单元格的数据组成的列表
print(sheet.row_values(10))  #打印出第11行数据组成的列表,后面会有空值,直至最大行值
# [11.0, '', '', '', '']
print(sheet.row_values(2,1,5))   # 打印出第3行从第2列-第5列数据组成的列表
# ['c', '三', '他', 45660.0]

# sheet.row_len(rowx)  #返回第 行的有值单元格长度
print(sheet.row_len(6))   #打印出第7行的有值单元格长度,   5

列相关操作:

# sheet.col(colx, start_rowx=0, end_rowx=None ) #获取由该列中所有的单元格对象组成的列表
print(sheet.col(3))  #打印出第4列对象组成的列表,后面会有空值,直至最大列值
# [text:'你', text:'我', text:'他', text:'她', text:'它', empty:'', empty:'', empty:'', empty:'', empty:'', empty:'', empty:'']
print(sheet.col(1,1,5))  #打印出第2列从第2行-第5行对象组成的列表
# [text:'b', text:'c', text:'d', text:'e']

# sheet.col_values(colx, start_rowx=0, end_rowx=None)   #获取由该列中所有单元格的数据组成的列表
print(sheet.col_values(2)) #打印出第3列数据组成的列表,后面会有空值,直至最长列值
# ['一', '二', '三', '四', '五', '六', '七', '', '', '', '', '']
print(sheet.col_values(2,3,7)) #打印出第3列从第4行-第7行数据组成的列表
# ['四', '五', '六', '七']

单元格相关操作:

# sheet.cell(rowx,colx) #获取单元格对象
print(sheet.cell(3,2))  #打印出C4(第4行第3列),    text:'四'

# sheet.cell_value(rowx,colx)  #获取单元格的值
print(sheet.cell_value(1,0))  # 打印出A2值(第2行第1列),    2.0
print(sheet.cell_value(0,4))   #打印出E1值(第1行第4列),45658.0, 
# 但并没有返回日期2025/1/1,python中没有与工作簿日期类型对应的数据类型

 # xlrd.xldate_as_datetime()
print(xlrd.xldate_as_datetime(sheet.cell_value(0,4),0))  # 2025-01-01 00:00:00

遍历所有数据:

for r in range(sheet.nrows):
    for c in range(sheet.ncols):
        print(f'第{r+1}行,第{c+1}列的数据是:{sheet.cell_value(r,c)}')

参考资料:

《Python办公自动化》,廖茂文

https://www.cnblogs.com/insane-Mr-Li/p/9092619.html

相关推荐

电脑装系统蓝屏(电脑装系统蓝屏重启开不了机)

蓝屏的原因往往集中在不兼容的硬件和驱动程序、有问题的软件、病毒等。解决办法:1、病毒的原因。使用电脑管家杀毒。2、内存的原因。用橡皮擦把内存条的金手指擦拭一下,把氧化层擦掉,确保内存条安装、运行正常。...

u盘安装软件(u盘安装软件到电视)

第一种情况:软件安装包可以直接下载的。在电脑上将软件安装包下载到本地硬盘,然后将下载好软件安装包拷贝到U盘上即可拿到别的电脑上去安装。分可为exe格式的和rar格式,exe格式直接安装,rar格式的解...

microsoft官网账户注册(microsoft 帐户注册)

要创建Microsoft账户,您可以按照以下步骤进行操作:1.打开任意一个支持浏览器的设备,如电脑、手机或平板电脑。2.在浏览器中输入"Microsoft账户注册"或直接访问Mic...

outlookcom官网(outlook online archive auto)
  • outlookcom官网(outlook online archive auto)
  • outlookcom官网(outlook online archive auto)
  • outlookcom官网(outlook online archive auto)
  • outlookcom官网(outlook online archive auto)
显示器闪屏是什么原因(显示器闪屏是哪里坏了)

解决方法:  一、接触不良导致的显示器闪屏  先查看主机和显示器的电源线连接,是否松动,重新插拔一下电源线。  二、信号干扰导致的显示器闪屏  1、连接显示器的电缆线是否没有屏蔽线圈,如果没有防干扰的...

国产linux操作系统(国产linux操作系统有什么版本)

中国对于操作系统的探索其实并不晚。  早在20世纪60年代中期中国就开始操作系统的研发,那时的比尔·盖茨还只是个迷恋计算机的小字辈,南京大学教授孙钟秀、北京大学杨芙清院士等都是我国操作系统的拓荒者...

免费无需排队的云电脑(不需要排队的云电脑)

目前市场上有一些云游戏平台提供无限时长且无需排队的服务。这些平台通常采用先进的云计算技术和高性能服务器,能够提供稳定流畅的游戏体验。用户可以随时登录并畅玩游戏,无需等待排队。这些平台还提供多种游戏选择...

视频播放器下载量排名(2020视频播放器排行榜)
  • 视频播放器下载量排名(2020视频播放器排行榜)
  • 视频播放器下载量排名(2020视频播放器排行榜)
  • 视频播放器下载量排名(2020视频播放器排行榜)
  • 视频播放器下载量排名(2020视频播放器排行榜)
wps官方下载(wps官方下载官网电脑版网址)

具体的步骤如下:1、首先在电脑上打开浏览器,在浏览器中输入“WPS”,找到WPS官方网站。2、接下来进入WPS官方网站中,找到WPS软件,点击“免费下载”。3、点击下载后在弹出来的对话框中修改下载位置...

win vista与win7有什么区别(win7与vista关系)

WindowsVista和Windows7是微软公司推出的两个桌面操作系统,它们之间有以下主要区别:1.界面设计:Windows7的界面设计更加简洁明了,而WindowsVista的界面...

winxp系统版本(winxp 版本)

1、微软官方3个版本:WINDOWSXPHOME(家庭版)、Professional(专业版)、MediaCenter2005(媒体中心版),每个版本的功能不一样。使用最多的是Professional...

打印机无法共享怎么回事(打印机无法共享出去)

共享打印机无法打印原因一:可能是由于病毒死机解决方法:确定是否由于病毒死机,找一张干净(确信无病毒)的系统盘,从A驱动舒上启动电脑,检查此时打印机和主机能否联机。如果正常联机,估计这种故障是由攻击硬件...

ipv6无网络访问权限怎么解决

ipv6无网络访问权限解决方法如下1、点击电脑左下角的开始,进入到开始的菜单栏,在菜单栏中找到“运行”。或者通过快捷键Windows+R打开运行窗口。  2、打开运行的窗口页面后,在页面上输入“CMD...

office ltsc版(Office LTSC版本区别)

office2021和2021ltsc的区别如下:1.更新策略不同。前者采用每个月月度更新的方法,提供功能更新、安全更新。后者不采用每个月月度更新的方法,且不提供功能更新。2.界面不同。2021采用了...

安装win7需要激活吗(现在安装win7旗舰版还需密钥吗)

要激活  Windows7如果是预装在计算机中的,买来之后便不用激活,这里预装指的是在厂商那里。正版的Windows7安装到计算机中,有三十天的试用期,若要永久使用,就要使...

取消回复欢迎 发表评论: