一、安装 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 模块)的更多相关文章

  1. python(读取excel操作-xlrd模块)

    一.安装xlrd模块 到python官网下载http://pypi.python.org/pypi/xlrd模块安装,前提是已经安装了python 环境. 或者在cmd窗口  pip install  ...

  2. Python 读取Excel之xlrd篇

    上一期给大家分享了如何用Python读取文本,这次给大家分享如何读取Excel表格内容,拿最常见的.xlsx和.xls格式来讲解. 本章主要知识点有: 读取整篇excel返回list[list[lis ...

  3. Python学习笔记:读取Excel的xlrd模块

    一.安装xlrd 可以使用命令行安装也可使用pycharm进行安装 表示xlrd库已经安装成功,安装成功后,我们就可以导入使用了. 二.xlrd说明 (1.单元格常用的数据类型包括 0:empty(空 ...

  4. Python 读取Excel数据 xlrd

    #导入相关模块 from xlrd import open_workbook #打开excel file = open_workbook("test.xlsx") #获取sheet ...

  5. 利用xlrd模块实现Python读取Excel文档

    # -*- coding: cp936 -*- #python读取excel import xlrd def main(): xls=xlrd.open_workbook("d:\\11.x ...

  6. [转] Windows下使用Python读取Excel表格数据

    http://www.python-excel.org/这个网站罗列了很多关于在Python下操作Excel文件的信息,这里选择了其介绍的第一个模块xlrd . xlrd 0.9.2版本跨平台同时支持 ...

  7. Python对Excel操作详解

      Python对Excel操作详解 文档摘要: 本文档主要介绍如何通过python对office excel进行读写操作,使用了xlrd.xlwt和xlutils模块.另外还演示了如何通过Tcl   ...

  8. Python读取Excel数据并根据列名取值

    一直想将自己接触到的东西梳理一遍,可就是迈不出第一步,希望从这篇总结开始不要再做行动的矮人了. 最近测试过程中需要用到python读取excel用例数据,于是去了解和学习了下xlrd库,这里只记录使用 ...

  9. python 读取excel数据并将测试结果填入Excel

    python 读取excel数据并将测试结果填入Excel 读取一个Excel中的一条数据用例,请求接口,然后返回结果并反填到excel中.过程中会生成请求回来的文本,当然还会生成一个xml文件.具体 ...

随机推荐

  1. Mac 系统root

    没错,你没看错,就是root mac系统安装件的时候,你有没有遇到过这种情况 总之,就是安装不上软件,肿么办? 网上解觉办法是: 进入系统偏好设置,设置为允许任何人,可是进去后这样: 别着急,打开命令 ...

  2. 合理使用CSS框架,加速UI设计进程

    转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 原文出处:https://dzone.com/articles/how-to-speed-up-your-d ...

  3. hive常用函数六

    cast 函数: 类型转换函数,cast(kbcount as int); case when: 条件判断,case when kbcount is not null and cast(kbcount ...

  4. JNDI数据源的配置及使用 (2010-11-21 21:16:43)转载▼

    JNDI数据源的配置及使用 (2010-11-21 21:16:43)转载▼ 标签: 杂谈 分类: 数据库 数据源的作用 JDBC操作的步骤: 1. 加载驱动程序 2. 连接数据库 3. 操作数据库 ...

  5. SpringBoot系列(六)集成thymeleaf详解版

    SpringBoot系列(六)集成thymeleaf详解版 1. thymeleaf简介  1. Thymeleaf是适用于Web和独立环境的现代服务器端Java模板引擎.  2. Thymeleaf ...

  6. 从联想昭阳到MacBook Pro,致我的那些败家玩意——电脑

    对于程序员来说,你懂的,电脑就是我们的女朋友,在很多层面上,它都是,打游戏.敲代码,以及看影片. 我第一台电脑是联想的笔记本(昭阳系列),花了 4000 多块买的. 那时候,家里很是缺钱,4000 多 ...

  7. DeepinV20系统文件管理器右键发送至为知笔记

    1. 创作背景 昨天在深度系统上做了一个打开文件管理器选择文件右键发送文本至博客园的插件. 这个插件对于我自己来说是及其方便的东西,平时的学习积累,工作经验或者生活感悟,随手记下之后,就能够轻松发送出 ...

  8. file_put_contens小trick

    file_put_contents tricks 0x01 trick1 来自于P神的实例: <?php $text = $_GET['text']; if(preg_match('[<& ...

  9. MVC-路由扩展-限制浏览器

    根据路由原理,MVC每次都会走获取路由上下文数据. 自定义Route 调用,以及完善其他代码 运行结果,当在谷浏览器执行时:

  10. vim环境下空格和tab键互换

    对于已保存的文件,可以使用下面的方法进行空格和TAB的替换 TAB替换为空格::set ts=4:set expandtab:%retab! 空格替换为TAB::set ts=4:set noexpa ...