Python中的xlrd模块使用原理解析


Posted in Python onMay 21, 2020

on里面的xlrd模块详解(一) - 疯了的小蜗 - 博客园【内容】:>

那我就一下面积个问题对xlrd模块进行学习一下:

  • 什么是xlrd模块?
  • 为什么使用xlrd模块?

1.什么是xlrd模块?

♦python操作excel主要用到xlrd和xlwt这两个库,即xlrd是读excel,xlwt是写excel的库。

今天就先来说一下xlrd模块:

一、安装xlrd模块

♦ 到python官网下载http://pypi.python.org/pypi/xlrd模块安装,前提是已经安装了python 环境。

♦或者在cmd窗口 pip installxlrd

二、使用介绍

1、常用单元格中的数据类型

♦ 0. empty(空的),1 string(text), 2 number, 3 date, 4 boolean, 5 error, 6 blank(空白表格)

2、导入模块

import xlrd

3、打开Excel文件读取数据

data = xlrd.open_workbook(filename)#文件名以及路径,如果路径或者文件名有中文给前面加一个r拜师原生字符。

 4、常用的函数

♦ excel中最重要的方法就是book和sheet的操作

1)获取book中一个工作表

table = data.sheets()[0]     #通过索引顺序获取
table = data.sheet_by_index(sheet_indx)) #通过索引顺序获取
table = data.sheet_by_name(sheet_name)#通过名称获取
以上三个函数都会返回一个xlrd.sheet.Sheet()对象
names = data.sheet_names()  #返回book中所有工作表的名字
data.sheet_loaded(sheet_name or indx)  # 检查某个sheet是否导入完毕

如:

Python中的xlrd模块使用原理解析

2)行的操作

nrows = 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) #返回该列的有效单元格长度

Python中的xlrd模块使用原理解析

3)列(colnum)的操作

ncols = table.ncols  #获取列表的有效列数
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_rowx=None)  #返回由该列中所有单元格的数据类型组成的列表
table.col_values(colx, start_rowx=0, end_rowx=None)  #返回由该列中所有单元格的数据组成的列表

如:

Python中的xlrd模块使用原理解析

4)单元格的操作

table.cell(rowx,colx)  #返回单元格对象
table.cell_type(rowx,colx)  #返回单元格中的数据类型
table.cell_value(rowx,colx)  #返回单元格中的数据
table.cell_xf_index(rowx, colx)  # 暂时还没有搞懂

♦单元格:单元格是表格中行与列的交叉部分,它是组成表格的最小单位,可拆分或者合并。单个数据的输入和修改都是在单元格中进行的

如:

Python中的xlrd模块使用原理解析

注意:注意作用域问题,之前获取的sheet之后,都在获取到这个sheet值后,在进行,行和列以及单元格的操作。

问题现象:

♦1、使用open()函数、xlrd.open_workbook()函数打开文件,文件名若包含中文,会报错找不到这个文件或目录。

♦2、获取sheet时若包含中文,也会报错。

#打开文件
file = open(filename,'rb')
#打开excel文件
workbook = xlrd.open_workbook(filename)
#获取sheet
sheet = workbook.sheet_by_name(sheetname)

解决方案:

♦对参数进行转码即可。如:

filename = filename.decode('utf-8')

♦也试过unicode函数,不过,在ride中运行时出现了报错,所以不赞成使用。

filename = unicode(filename,'utf-8')

2.为什么使用xlrd模块?

♦在UI自动化或者接口自动化中数据维护是一个核心,所以此模块非常实用。

Python 相关文章推荐
python处理文本文件实现生成指定格式文件的方法
Jul 31 Python
Python操作MySQL简单实现方法
Jan 26 Python
Python删除windows垃圾文件的方法
Jul 14 Python
Python入门_学会创建并调用函数的方法
May 16 Python
Python实现字符串反转的常用方法分析【4种方法】
Sep 30 Python
PyQt5每天必学之工具提示功能
Apr 19 Python
Python数据可视化实现正态分布(高斯分布)
Aug 21 Python
关于Python形参打包与解包小技巧分享
Aug 24 Python
python__new__内置静态方法使用解析
Jan 07 Python
python多进程使用函数封装实例
May 02 Python
python2.7使用scapy发送syn实例
May 05 Python
使用TensorBoard进行超参数优化的实现
Jul 06 Python
python中sklearn的pipeline模块实例详解
May 21 #Python
Python使用re模块验证危险字符
May 21 #Python
Django 解决新建表删除后无法重新创建等问题
May 21 #Python
python 解决Fatal error in launcher:错误问题
May 21 #Python
django实现日志按日期分割
May 21 #Python
Django之富文本(获取内容,设置内容方式)
May 21 #Python
使用Python防止SQL注入攻击的实现示例
May 21 #Python
You might like
深入剖析PHP中printf()函数格式化使用
2016/05/23 PHP
php 遍历目录,生成目录下每个文件的md5值并写入到结果文件中
2016/12/12 PHP
php使用crypt()函数进行加密
2017/06/08 PHP
js 目录列举函数
2008/11/06 Javascript
网易JS面试题与Javascript词法作用域说明
2010/11/09 Javascript
JQuery将文本转化成JSON对象需要注意的问题
2011/05/09 Javascript
Js 去掉字符串中的空格(实现代码)
2013/11/19 Javascript
用Javascript获取页面元素的具体位置
2013/12/09 Javascript
Node.js中对通用模块的封装方法
2014/06/06 Javascript
JS递归遍历对象获得Value值方法技巧
2016/06/14 Javascript
JavaScript组合模式学习要点
2016/08/26 Javascript
AngularJS 控制器 controller的详解
2017/10/17 Javascript
vue element项目引入icon图标的方法
2018/06/06 Javascript
angular2实现统一的http请求头方法
2018/08/13 Javascript
详解离线安装npm包的几种方法
2018/11/25 Javascript
jQuery.parseJSON()函数详解
2019/02/28 jQuery
微信小程序结合Storage实现搜索历史效果
2019/05/18 Javascript
vue实现在v-html的html字符串中绑定事件
2019/10/28 Javascript
VUE UPLOAD 通过ACTION返回上传结果操作
2020/09/07 Javascript
Python的条件语句与运算符优先级详解
2015/10/13 Python
Python3使用pandas模块读写excel操作示例
2018/07/03 Python
对pytorch网络层结构的数组化详解
2018/12/08 Python
Python 获取div标签中的文字实例
2018/12/20 Python
Python3模拟curl发送post请求操作示例
2019/05/03 Python
如何解决tensorflow恢复模型的特定值时出错
2020/02/06 Python
Flask缓存静态文件的具体方法
2020/08/02 Python
CSS3 伪类选择器 nth-child()说明
2010/07/10 HTML / CSS
For Art’s Sake官网:手工制作的奢华眼镜
2018/12/15 全球购物
SOA的常见陷阱或者误解是什么
2014/10/05 面试题
派出所正风肃纪剖析材料
2014/10/10 职场文书
先进个人事迹材料
2014/12/29 职场文书
世界红十字日活动总结
2015/02/10 职场文书
消防演习通知
2015/04/25 职场文书
《赵州桥》教学反思
2016/02/17 职场文书
2016优秀员工先进事迹材料
2016/02/25 职场文书
Node实现搜索框进行模糊查询
2021/06/28 Javascript