python xlrd读取excel
python怎么xlrd读取excel呢?不知道的小伙伴来看看小编今天的分享吧!
import xlrd # 导入xlrd模块
1、打开excel文件,获取文件内容
excel = '/Users/usr/Downloads/TEMP/DVT.xlsx'
data = xlrd.open_workbook(excel)
data.nsheets # 获取该excel文件中包含的sheet的数量
data.sheets() # 返回该excel文件中所有sheet对象组成的列表
data.sheet_names() # 返回该excel文件中所有sheet名称组成的列表
data.sheet_names()[index] # 获取excel文件中指定索引的sheet的名称
data.sheet_loaded(sheet_name or index) # 检查某个sheet是否导入完毕
2、获取某个sheet数据
table = data.sheets()[index] # 根据sheet索引获取sheet内容
table = data.sheet_by_index(index) # 根据sheet索引获取sheet内容
table = data.sheet_by_name(sheet_name) # 根据sheet名称获取sheet内容
table.name # 获取sheet名称
3、操作行、列、单元格
# 行的操作
table.nrows # 获取该sheet中的有效行数
table.row(rowx) # 返回由该行中所有单元格对象组成的列表
table.row_slice(rowx) # 返回由该列中所有的单元格对象组成的列表
table.row_types(rowx,start_colx=0,end_colx=None) # 返回由该行中所有单元格的数据类型组成的列表
table.row_values(rowx,start_colx=0, end_colx=None) # 返回由该行中所有单元格数据组成的列表
table.row_len(rowx) # 返回该列的有效单元格长度
# 列的操作
table.ncols # 获取该sheet中的有效列数
table.col(colx,start_rowx=0,end_rowx=None)
table.col_slice(colx,start_rowx=0,end_rowx=None)
table.col_types(colx,start_rowx=0,end_rows=None)
table.col_values(colx,start_rowx=0,end_rows=None)
# 单元格的操作
table.cell(rowx,colx) # 返回单元格对象
table.cell_value(rowx,colx) # 返回单元格中的数据
table.cell(rowx,colx).value
table.row(rowx)[index].value
table.col(colx)[index].value
table.cell_type(rowx,colx) # 返回单元格中的数据类型
sheet2.cell(rowx,colx).ctype
table.row(rowx)[index].ctype
table.col(colx)[index].ctype
4、获取单元格内容为特定类型方式
# ctype: 0 empty,1 string,2 number,3 date,4 boolean,5 error,6 blank
# 获取单元格内容为date格式
from datetime import datetime,date
if sheet1.cell(3,6).ctype == 3:
cell_value = sheet1.cell(3,6).value)
date_value = xlrd.xldate_as_tuple(cell_value, data.datemode)
date_value_str = date(*data_value[:3])
date_value_str = date(*data_value[:3]).strftime('%Y/%m/%d')
# 获取单元格内容为number(int)格式
if sheet1.cell(3,5).ctype == 2:
cell_value = sheet1.cell(3,5).value
num_value = int(cell_value)
5、获取合并单元格的内容
data = xlrd.open_workbook(filename, formattinng_info=True)
sheet1 = data.sheet_by_name('OTA_02')
sheet1.merged_cells
# 返回: (row,row_range,col,col_range)
# 总结规律: 获取merge_cells返回的row和col的低位索引即可
merge_value = []
for (row,row_range,col,col_range) in sheet1.merged_cells:
merge_value.append((row,col))
print(merge_value)
for v in merge_value:
cell_value = sheet1.cell(v[0],v[1]).value
print(cell_value)
6、打开包含中文字符的文件名和sheet名时报错的解决办法
# 1.使用open()函数,xlrd.open_workbook()函数打开文件,文件名若包含中文,会报错找不到这个文件或目录
# 2.获取sheet时,若包含中文,也会报错
file = open(filename,'rb') # 打开文件
workbook = xlrd.open_workbook(filename) # 打开excel文件
sheet = workbook.sheet_by_name(sheetname) # 获取sheet
# 解决方案:
# a.对参数进行转码即可,如:
filename = filename.decode('utf-8')
# b.也试过unicode函数,不过,在ride中运行时出现了报错,不推荐
filename = unicode(filename,'utf-8')
-
911百公里加速多少
保时捷911的普通版车型百公里加速时间为4.2秒。911是保时捷旗下的一款跑车,911是一款后置发动机车型。911系列车型使用了水平对置发动机,保时捷和斯巴鲁是全世界唯一两家使...
问答查看全文>> -
哈弗h6钥匙没电了怎么启动车
首先需要使用车辆的机械钥匙,通过机械钥匙打开车辆,然后踩下刹车踏板,将遥控钥匙放在一键启动的位置,按下一键启动按键,机动车辆就可以启动。在车辆启动之后,及时为车辆的遥控钥匙更换...
问答查看全文>> -
特斯拉Model Y落地价多少?特斯拉Model Y 2022款价格
Model Y是特斯拉在2021年推出的一款纯电动中型SUV,由于这款车的外观和Model X非常相似,而且新车售价和Model 3一样亲民,所以车型刚上市就获得了很高的销量,...
问答查看全文>> -
闯红灯扣几分多久清零?
闯一次红灯扣6分,2次红灯驾驶证就没有了:1、积分清零是在计分周期到了而且处理了违章,交啦罚款才能清零的,11分(C照)以内没有事处理了违章就可以了,超过12分就麻烦了,要去车...
问答查看全文>>
推荐
- 1水箱宝与防冻液的区别433
- 2迈锐宝油耗是多少?366
- 3东风天锦kr上市了吗?345
- 4小米12录屏声音在哪里设置的 小米12录屏声音怎么开438
- 5适合发空间的伤感语录178
- 6君威gs超级运动版有运动模式吗?181
- 7车身防撞条怎样去除?351
- 8科三靠边停车后要关转向灯吗?141