python(读取 excel 操作 xlrd 模块)
一、安装 xlrd 模块
- 到 python 官网下载 http://pypi.python.org/pypi/xlrd 模块安装,前提是已经安装了 python 环境。
- 或者在 cmd 窗口 pip install xlrd
二、excel 读取操作
1.常用的函数
- excel 中最重要的方法就是 book 和 sheet 的操作
1)获取 book 中一个工作表
#coding=utf-8
import xlrd
data = xlrd.open_workbook("d:\\test.xls") #打开excel文件
print (data.sheets()[0]) #通过索引顺序获取sheet对象
print (data.sheet_by_index(0)) #通过索引顺序获取sheet对象
print (data.sheet_by_name("Sheet1")) #通过名称获取sheet对象
print (data.sheet_names()) #返回book中所有工作表的名字
#结果如下
--> <xlrd.sheet.Sheet object at 0x0000000003D969B0>
--> <xlrd.sheet.Sheet object at 0x0000000003D969B0>
--> <xlrd.sheet.Sheet object at 0x0000000003D969B0>
--> [u'Sheet1', u'Sheet2', u'Sheet3']
#coding=utf-8
import xlrd
book = xlrd.open_workbook("C:\\Users\\Administrator\\Desktop\\aaa.xls")
sheet = book.sheets()[0]
#通过for循环遍历取出excel表中第一列所有的数据
for i in range(sheet.nrows):
print (sheet.row_values(i)[0])
2)行的操作
- nrows #获取该 sheet 中的有效行数
- row(row_index) #返回由该行中所有的单元格对象组成的列表
- row_slice(row_index, start_colx=0, end_colx=None) #默认返回由该行中所有的单元格对象组成的列表(结果只能返回 end_colx 前值)
- row_values(row_index, start_colx=0, end_colx=None) #默认返回由该行中所有单元格的数据组成的列表(结果只能返回 end_colx 前值)
- row_len(index) #返回该行的有效单元格长度
#coding=utf-8
import xlrd
data = xlrd.open_workbook("d:\\test.xls")
sheet = data.sheets()[0]
print (sheet.nrows) #获取该sheet中的有效行数
print (sheet.row(0)) #返回由该行中所有的单元格对象组成的列表
print (sheet.row_slice(0)) #默认返回由该行中所有的单元格对象组成的列表
print (sheet.row_values(0,1)) #默认返回由该行中所有单元格的数据组成的列表
print (sheet.row_len(0)) #索引值为0的行中有效单元格有几个
#结果如下
--> 10
--> [text:u'user1', text:u'pwd1']
--> [text:u'user1', text:u'pwd1']
--> [u'pwd1']
--> 2
3)列(colnum)的操作
- ncols #获取列表的有效列数
- col(col_index, start_rowx=0, end_rowx=None) #默认返回由该列中所有的单元格对象组成的列表(结果只能返回 end_rowx 前值)
- col_slice(col_index, start_rowx=0, end_rowx=None) #默认返回由该列中所有的单元格对象组成的列表(结果只能返回 end_rowx 前值)
- col_values(col_index, start_rowx=0, end_rowx=None) #默认返回由该列中所有单元格的数据组成的列表(结果只能返回 end_rowx 前值)
#coding=utf-8
import xlrd
data = xlrd.open_workbook("d:\\test.xls")
sheet = data.sheets()[0]
print (sheet.ncols) #获取列表的有效列数
print (sheet.col(0,0,2)) #返回第一行和第二行的单元格对象组成的列表
print (sheet.col_slice(0,0,2)) #返回第一行和第二行的单元格对象组成的列表
print (sheet.col_values(0,0,2)) #返回第一行和第二行的单元格数据组成的列表
#结果如下
--> 2
--> [text:u'user1', text:u'user2']
--> [text:u'user1', text:u'user2']
--> [u'user1', u'user2']
4)单元格的操作
- cell(row_index,col_index) #返回单元格对象
- cell_value(row_index,col_index) #返回单元格中的数据
#coding=utf-8
import xlrd
data = xlrd.open_workbook("d:\\test.xls")
sheet = data.sheets()[0]
print (sheet.cell(0,0)) #返回第一行第一列单元格对象
print (sheet.cell_value(0,0)) #返回第一行第一列单元格中的数据
#结果如下
--> text:u'user1'
--> user1
5)读取 excel 方法封装
#coding=utf-8
import xlrd
class ReadExcel():
def __init__(self,file,sheet_i):
self.book = xlrd.open_workbook(file)
self.sheet = self.book.sheet_by_index(sheet_i)
def getValue(self,row_i,col_i):
"""
获取excel单元格数据
"""
return self.sheet.cell_value(row_i,col_i)
def getRows(self):
"""
获取有效行数
"""
return self.sheet.nrows
def getCols(self):
"""
获取有效列数
"""
return self.sheet.ncols
2.单元格是表格中行与列的交叉部分,它是组成表格的最小单位,可拆分或者合并。单个数据的输入和修改都是在单元格中进行的如:
注意:注意作用域问题,之前获取的 sheet 之后,都在获取到这个 sheet 值后,在进行,行和列以及单元格的操作。
问题现象:
- 使用 open() 函数、xlrd.open_workbook() 函数打开文件,文件名若包含中文,会报错找不到这个文件或目录。
- 获取 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')
python(读取 excel 操作 xlrd 模块)的更多相关文章
- python(读取excel操作-xlrd模块)
一.安装xlrd模块 到python官网下载http://pypi.python.org/pypi/xlrd模块安装,前提是已经安装了python 环境. 或者在cmd窗口 pip install ...
- Python 读取Excel之xlrd篇
上一期给大家分享了如何用Python读取文本,这次给大家分享如何读取Excel表格内容,拿最常见的.xlsx和.xls格式来讲解. 本章主要知识点有: 读取整篇excel返回list[list[lis ...
- Python学习笔记:读取Excel的xlrd模块
一.安装xlrd 可以使用命令行安装也可使用pycharm进行安装 表示xlrd库已经安装成功,安装成功后,我们就可以导入使用了. 二.xlrd说明 (1.单元格常用的数据类型包括 0:empty(空 ...
- Python 读取Excel数据 xlrd
#导入相关模块 from xlrd import open_workbook #打开excel file = open_workbook("test.xlsx") #获取sheet ...
- 利用xlrd模块实现Python读取Excel文档
# -*- coding: cp936 -*- #python读取excel import xlrd def main(): xls=xlrd.open_workbook("d:\\11.x ...
- [转] Windows下使用Python读取Excel表格数据
http://www.python-excel.org/这个网站罗列了很多关于在Python下操作Excel文件的信息,这里选择了其介绍的第一个模块xlrd . xlrd 0.9.2版本跨平台同时支持 ...
- Python对Excel操作详解
Python对Excel操作详解 文档摘要: 本文档主要介绍如何通过python对office excel进行读写操作,使用了xlrd.xlwt和xlutils模块.另外还演示了如何通过Tcl ...
- Python读取Excel数据并根据列名取值
一直想将自己接触到的东西梳理一遍,可就是迈不出第一步,希望从这篇总结开始不要再做行动的矮人了. 最近测试过程中需要用到python读取excel用例数据,于是去了解和学习了下xlrd库,这里只记录使用 ...
- python 读取excel数据并将测试结果填入Excel
python 读取excel数据并将测试结果填入Excel 读取一个Excel中的一条数据用例,请求接口,然后返回结果并反填到excel中.过程中会生成请求回来的文本,当然还会生成一个xml文件.具体 ...
随机推荐
- 【Mongodb】视图 && 索引
准备工作 准备2个集合的数据,后面视图和索引都会用到1个订单集合,一个收款信息集合 var orders = new Array(); var shipping = new Array(); var ...
- pyecharts的使用及总结
包的下载及配置 这个包的相应的配置较多,版本也不兼容,总结一下 预览:pyecharts画图 pip pyecharts pip 各级别地图(6.7个左右) pip jupyter环境 [为了生成pn ...
- Atlas运行时资源不足报错 -bash: fork: retry: 资源暂时不可用 Out of system resources
目的:运行Atlas并使用Azkaban执行操作任务 环境:Centos 6 内存大小:12G 启动下面的任务后还剩内存将近5G 问题: 当mysql_to_hdfs_db和其他job同时运行时集群很 ...
- Powershell如何制定属性并输出
这个标题看着有些云里雾里.... 前一阵,群里有个朋友问博主“我想把所有用户的SMTP地址全部输出到CSV文件中进行统计,但是SMTP地址似乎输出的是错误的,可在shell里看输出的内容是正确的阿” ...
- OO第三单元作业分析
一.JML的理论基础应用工具链 JML是用于对Java程序进行规格化设计的一种表示语言.基于Larch方法构建. (1)注释 JML以javadoc注释的方式来表示规格,每行都以@起头.有两种注释方式 ...
- 3分钟掌握Quartz.net分布式定时任务的姿势
引言 长话短说,今天聊一聊分布式定时任务,我的流水账笔记: ASP.NET Core+Quartz.Net实现web定时任务 AspNetCore结合Redis实践消息队列 细心朋友稍一分析,就知道还 ...
- 通过Java HTTP连接将网络图片下载到本地
通过Java HTTP连接将网络图片下载到本地 只知道浏览器使用的是HTTP协议,那么如何将网络资源使用JavaHTTP下载下来呢! 这只是一个非常简单的小示例,只是不想每次碰到关于此方面的内容忘 ...
- 编写高质量Python程序(三)基础语法
本系列文章为<编写高质量代码--改善Python程序的91个建议>的精华汇总. 关于导入模块 Python的3种引入外部模块的方式:import语句.from ... import ... ...
- Docker-CentOS系统安装Docker
上一节,我们介绍了安装虚拟机及操作系统,本文再详细描述安装docker的命令. 前提条件 虚拟机系统:CentOS,并且虚拟机能连通外网. 另外,虚拟机最好配置上阿里的镜像源,点此链接,进入cento ...
- Docker搭建Nessus pro笔记
0x01 准备Docker环境 拉取镜像: docker pull ubuntu 创建容器: docker run -p 9922:22 -p 8834:8834 --name nessus -it ...