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

Python,xlrd读取excel,公共方法讲解及代码示例

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

Python,xlrd读取excel,公共方法讲解(思维导图)以及代码示例

对应视频讲解地址:Python接口自动化测试实战15 xlrd读取excel

一、思维导图

二、代码示例:

#!/usr/bin/env python

"""

@desc:读取excel操作

"""

import os

import xlrd

from datetime import date,datetime

newpath = os.chdir(r'D:\python_pycharmWorkspace\python36\Interface_Test_Training\test_case\excel_train')

filename = "100G测试资源(视频+教程)免费获取.xlsx"

file = os.path.join(os.getcwd(),filename)

'''一、打开文件'''

xl = xlrd.open_workbook(file) #打开excel

'''二、获取sheet'''

print(xl.sheet_names())#获取所有sheet的名字

print(xl.nsheets)

print(xl.sheets())

print(xl.sheet_by_name('目录')) #通过名称获取

print(xl.sheet_by_index(1)) #通过索引获取

'''三、获取sheet内的汇总数据'''

table1 = xl.sheet_by_name('目录')

print(table1.name) #获取sheet的名称

print(table1.nrows) #获取总行数

print(table1.ncols) #获取总列数

'''四、单元格批量读取'''

print(table1.row_values(0)) #返回包含第1行值的列表,注意合并单元格,只能取第1个的值,其他为空

print(table1.row(0))

print((table1.row_types(0)))

print(table1.row_values(1))#返回包含第2行值的列表

print(table1.row_values(1,0,2))#返回包含第2行,包含第1列和第2列的值

print(table1.row_slice(1,0,2)) #list [text:'QQ群号', number:205089395]

print(table1.row_types(1,0,2)) # <class 'array.array'> array('B', [1, 2])

print(table1.col_values(1,0,2))#返回包含第2列,包含第1行和第2行的值

print(table1.col_values(0)) #返回包含第1列值的列表,注意合并单元格,只能取第1个的值,其他为空

print(table1.col_values(2)) #返回包含第3列值的列表

'''五、特定单元格读取'''

print(table1.cell(1,2).value)#获取第2行,第3列单元格的值

print(table1.cell_value(1,2))

print(table1.row(1)[2])

print(table1.row(1)[2].value)

print(table1.row(1)[2].ctype)

'''六、常用技巧:(0,0)转换成A1'''

print(xlrd.cellname(0,0)) #A1 cellname方法把一对行和列索引转换为一个对应的Excel单元格引用

print(xlrd.cellnameabs(0,0)) #$A$1 cellnameabs方法把一对行和列索引转换为一个绝对的Excel单元格引用(如:$A$1)

print(xlrd.colname(0)) #A colname方法把一个列索引转换为Excel列名

'''七、获取表格内不同类型的name'''

def read_excel(table,row,col):

name = table.cell_value(row,col)

ctype = table.cell_type(row,col)

if ctype == 0:

name = "''"

elif ctype == 1:

name = name

elif ctype == 2 and name % 1 == 0:

name = int(name)

elif ctype == 3:

'''方法一'''

date_value = xlrd.xldate_as_tuple(name,0) #转换为元组形式 (2017, 11, 11, 0, 0, 0)

# name = date(*date_value[:3]).strftime('%Y/%m/%d') #date_value[:3]为(2017, 11, 11) *date_value[:3]为 2017 11 11

name = datetime(*date_value).strftime('%Y/%m/%d %H:%M:%S') #datetime指日期时间,date只是至日期

# name = time.strftime("%Y-%m-%d %H:%M:%S", date_value) #time模块也可以,但需要元组传递9个值,目前只有6个

'''方法二'''

# date_value = datetime(*xlrd.xldate_as_tuple(name, 0)) #date

# name = date_value.strftime('%Y/%d/%m %H:%M:%S')

'''方法三'''

# date_value = xlrd.xldate.xldate_as_datetime(name, 0) # 直接转化为datetime对象

# name = date_value

elif ctype == 4:

name = True if name == 1 else False

return name

#ctype : 0 empty, 1 string, 2 number, 3 date, 4 boolean, 5 error

# 5 error 这是由xlrd.XL_CELL_ERROR常数表示的。这种单元格的值是表示特定错误代码的整数。error_text_from_code方法用来把错误代码转换为错误信息

# print(table1.cell_type(1,0)) #返回1,字符串

print(table1.cell_value(1,0))

print(read_excel(table1,1,0))

# print(table1.cell_type(1,1)) #返回2,数字

print(table1.cell_value(1,1))

print(read_excel(table1,1,1))

# print(table1.cell_type(0,1)) #返回0,empty

print(table1.cell_value(0,1))

print(read_excel(table1,0,1))

# print(table1.cell_type(0,7)) #返回3,日期

print(table1.cell_value(0,7))

print(read_excel(table1,0,7))

# print(table1.cell_type(0,8)) #返回4,布尔,0位false,1为True

print(table1.cell_value(0,8))

print(read_excel(table1,0,8))

相关推荐

路由器账号和密码忘了怎么办

你好,如果你忘记了路由器的用户名和密码,你可以尝试重置一下路由器,大多数路由器都配备了一个复位按键。在重置路由器之后,用户名和密码将被还原为默认值,你可以在路由器的用户手册或厂家网站上找到默认的用户名...

win10永久禁止自动更新(win10禁止自动更新彻底)

阻止Windows10自动更新的方法如下:使用“本地组策略编辑器”:按下“Win+R”键,输入“gpedit.msc”打开本地组策略编辑器,找到“计算机配置”>“管理模板”>“W...

联想笔记本怎么看配置和型号

联想笔记本看配置的方法如下1、打开电脑,点击桌面的计算机,右键菜单里选择【属性】;打开后,即可看到电脑系统的大概信息;2、如果要看比较详细的设备相关信息,点击桌面的计算机,点击右键,在菜单里选择【系统...

怎样把打印机连接到电脑上(怎么把打印机连接电脑上)
  • 怎样把打印机连接到电脑上(怎么把打印机连接电脑上)
  • 怎样把打印机连接到电脑上(怎么把打印机连接电脑上)
  • 怎样把打印机连接到电脑上(怎么把打印机连接电脑上)
  • 怎样把打印机连接到电脑上(怎么把打印机连接电脑上)
photoshop6序列号(photoshop8.01序列号)
  • photoshop6序列号(photoshop8.01序列号)
  • photoshop6序列号(photoshop8.01序列号)
  • photoshop6序列号(photoshop8.01序列号)
  • photoshop6序列号(photoshop8.01序列号)
win10下载应用商店(win10应用商店打不开)

1、点击Win10系统的开始菜单,然后在点击应用商店;2、打开Win10应用商店后,在搜索框里输入想要搜索的应用软件,然后点击检索;3、点击搜索到的应用,点击安装;4、点击安装后,系统会提示要切换到这...

dell电脑重装系统win10(dell 重装win10系统)

戴尔笔记本重装系统win10的步骤如下:制作好wepe启动盘之后,将win10系统iso镜像直接复制到U盘。在需要重装系统的戴尔电脑上插入pe启动盘,重启后不停按F12启动快捷键,调出启动菜单对话框,...

android升级包下载安装(android 升级包)

打开手机系统更新升级,前提是官方有新系统推送才能更新  哪个大不一定,但一般规律如下:  1、小版本的更新,通常越更新越大。比如3.1更新到3.2,通常是修复bug,代码量通常会增大,体积就会增大。 ...

hdd硬盘和ssd(ssd硬盘和hdd硬盘是什么意思)

HDD硬盘和SSD硬盘是两种不同类型的电脑存储设备,它们有着以下区别:1.工作原理:HDD硬盘使用机械旋转的磁盘和读写磁头来存储和读取数据,而SSD硬盘则使用闪存存储数据,类似于USB闪存盘。2....

电脑免费软件下载大全(电脑上免费的下载软件)

正常情况下,如果我们想要在自己的电脑上面下载一个不要钱的单机游戏,那么我们是可以直接在我们的软件管理中心进行一个下载的,这个时候我们只需要通过一个权限就能够正常的下载,当然我们也是可以在一些小游戏的软...

mpp文件转换excel(mpp转换成pdf)

要将Excel表格转换为MPP格式,您可以按照以下步骤操作:1.打开Excel表格并确保数据按照项目的不同阶段或任务进行组织。2.将Excel表格中的数据复制到一个新的MicrosoftProj...

win7旗舰版开机密码忘记按f2

方法如下:开始-控制面板-用户帐户;在打开的更改用户帐户界面点击要更改的帐户;然后点击帐户左面的更改密码按钮;在打开的页面上,输入一次当前使用的密码,输入2次要更改的新密码然后保存退出就可以了...

笔记本无音频输出设备(笔记本无音频输出设备)

1、没有声卡驱动,解决方法就是找到笔记本的官网,下载电脑声卡的驱动安装即可。2、没有外界的音频播放设备,解决方法就是买一个外界的音频播放设备插到电脑主机的音频接口上即可。笔记本电脑显示未安装任何音频输...

iso文件能用手机打开吗(iso文件能用手机打开吗安全吗)

一般的压缩软件就可以打开的,比如,好压软件,这个打开只是解压形式的,如果你说的是运行iso文件,这个没有,况且安卓系统也不支持iso运行ISO文件一般用于光盘镜像文件的存储,如果想要在手机上运行ISO...

win7系统卡顿怎么优化(win7很慢很卡怎么优化)

1、首先打开安全卫士,进入安全卫士首页,单击软件窗口右下角的“更多”图标,打开扩展应用程序。2、单击选择“我的工具”。3、在我的工具菜单里面找到“人工服务”单击打开人工服务。4、在人工服务对话框有很多...

取消回复欢迎 发表评论: