Python帮你玩转Excel文档之xlrd模块的基本详细操作

阅读前小读:
(1)本博文针对的Excel文档是以 .xls 结尾的文档
(2)此次操作的文档来源为国家统计局官网中的季度数据,大家也可以登陆国家统计局官网自行下载
(3)一个Excel文档等价于一个“工作簿”,一个“工作簿”中又可包含多个“工作表”
(4)给出所用表的相关信息:
在这里插入图片描述

1.导入模块

第一行代码用于对整体 .py 文件的字符格式设置,防止出现代码中出现中文时乱码或者报错

#coding=utf-8
import xlrd

2.获取工作薄(workbook)

创建工作簿(workbook)
返回类型 <xlrd.book.Book object at 0x000002DB9D3DC4A8>

#创建工作簿(workbook),返回类型 <xlrd.book.Book object at 0x000002DB9D3DC4A8>
workbook = xlrd.open_workbook('季度数据.xls')

3.获得工作表(worksheet)相关信息的操作

(print 下的注释为本 print 的输出)

#获得所有worksheet的名字
names = workbook.sheet_names()
print(names)
#['季度数据']

#通过索引获得worksheet工作表对象
worksheet = workbook.sheet_by_index(0)
print(worksheet)
#<xlrd.sheet.Sheet object at 0x000001C050D36B38>

#通过名字获得worksheet工作表对象
worksheet = workbook.sheet_by_name('季度数据')
print(worksheet)
#<xlrd.sheet.Sheet object at 0x000001C050D36B38>

#通过索引顺序获取
worksheet = workbook.sheets()[0]
print(worksheet)
#<xlrd.sheet.Sheet object at 0x000001A480A47B70>

#检查某个sheet是否导入完毕
print(workbook.sheet_loaded(0))
print(workbook.sheet_loaded('季度数据'))
# True
# True

#获取所有表名
name = worksheet.name
print(name)
#季度数据

4.对于工作表"行"的操作

'''对于工作表行的操作'''
#获取表的总行数
nrows = worksheet.nrows
print(nrows)
# 19

#返回该行所有单元格对象组成的列表,这个行数的下表是从0开始的
list_1 = worksheet.row_slice(3)
print(list_1)
#[text:'国内生产总值当季值(亿元)', number:278019.7, number:252208.7, number:242573.8, number:218062.8, number:258808.9, number:234474.3]

#返回该行所有单元格的数据类型组成的列表
list_2 = worksheet.row_types(3,start_colx=0,end_colx=None)
print(list_2)
#array('B', [1, 2, 2, 2, 2, 2, 2])

#返回该行所有单元格的数据组成的列表
list_3 = worksheet.row_values(3,start_colx=0,end_colx=None)
print(list_3)
#['国内生产总值当季值(亿元)', 278019.7, 252208.7, 242573.8, 218062.8, 258808.9, 234474.3]

#返回该行的有效单元格长度
print(worksheet.row_len(3))
# 7

5.对于工作表"列"的操作


'''对于工作表列的操作'''
#获取有效列
ncols = worksheet.ncols
print(ncols)

#返回该行所有单元格对象组成的列表,这个行数的下表是从0开始的
list_4 = worksheet.col_slice(0)
print(list_4)
#[text:'数据库:季度数据', text:'时间:最近6季度', text:'指标', text:'国内生产总值当季值(亿元)', text:'国内生产总值累计值(亿元)', text:'第一产业增加值当季值(亿元)', text:'第一产业增加值累计值(亿元)', text:'第二产业增加值当季值(亿元)', text:'第二产业增加值累计值(亿元)', text:'第三产业增加值当季值(亿元)', text:'第三产业增加值累计值(亿元)', text:'农林牧渔业增加值当季值(亿元)', text:'农林牧渔业增加值累计值(亿元)', text:'工业增加值当季值(亿元)', text:'注:1.按当年价格计算。累计数据由当季数据相加得到。', text:'\u3000\u3000\u30002.三次产业分类依据国家统计局2018年修订的《三次产业划分规定》。第一产业是指农、林、牧、渔业(不含农、林、牧、渔专业及辅助性活动);第二产业是指采矿业(不含开采专业及辅助性活动),制造业(不含金属制品、机械和设备修理业),电力、热力、燃气及水生产和供应业,建筑业;第三产业即服务业,是指除第一产业、第二产业以外的其他行业。', text:'\u3000\u3000\u30003.行业分类采用《国民经济行业分类(GB/T 4754-2017)》。', text:'\u3000\u3000\u30004.2015年之前各季度,其他服务业包含信息传输、软件和信息技术服务业,租赁和商务服务业,科学研究和技术服务业,水利、环境和公共设施管理业,居民服务、修理和其他服务业,教育,卫生和社会工作,文化、体育和娱乐业,公共管理、社会保障和社会组织共9个门类行业;2015年及之后各季度,其他服务业包含科学研究和技术服务业,水利、环境和公共设施管理业,居民服务、修理和其他服务业,教育,卫生和社会工作,文化、体育和娱乐业,公共管理、社会保障和社会组织共7个门类行业。', text:'数据来源:国家统计局']

# 返回该行所有单元格的数据类型组成的列表
list_5 = worksheet.col_types(0,start_rowx=2,end_rowx=None)
print(list_5)
#[1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1]

# 返回该行所有单元格的数据组成的列表
list_6 = worksheet.col_values(0,start_rowx=2,end_rowx=None)
print(list_6)
#['指标', '国内生产总值当季值(亿元)', '国内生产总值累计值(亿元)', '第一产业增加值当季值(亿元)', '第一产业增加值累计值(亿元)', '第二产业增加值当季值(亿元)', '第二产业增加值累计值(亿元)', '第三产业增加值当季值(亿元)', '第三产业增加值累计值(亿元)', '农林牧渔业增加值当季值(亿元)', '农林牧渔业增加值累计值(亿元)', '工业增加值当季值(亿元)', '注:1.按当年价格计算。累计数据由当季数据相加得到。', '\u3000\u3000\u30002.三次产业分类依据国家统计局2018年修订的《三次产业划分规定》。第一产业是指农、林、牧、渔业(不含农、林、牧、渔专业及辅助性活动);第二产业是指采矿业(不含开采专业及辅助性活动),制造业(不含金属制品、机械和设备修理业),电力、热力、燃气及水生产和供应业,建筑业;第三产业即服务业,是指除第一产业、第二产业以外的其他行业。', '\u3000\u3000\u30003.行业分类采用《国民经济行业分类(GB/T 4754-2017)》。', '\u3000\u3000\u30004.2015年之前各季度,其他服务业包含信息传输、软件和信息技术服务业,租赁和商务服务业,科学研究和技术服务业,水利、环境和公共设施管理业,居民服务、修理和其他服务业,教育,卫生和社会工作,文化、体育和娱乐业,公共管理、社会保障和社会组织共9个门类行业;2015年及之后各季度,其他服务业包含科学研究和技术服务业,水利、环境和公共设施管理业,居民服务、修理和其他服务业,教育,卫生和社会工作,文化、体育和娱乐业,公共管理、社会保障和社会组织共7个门类行业。', '数据来源:国家统计局']

6.精准获取某一单元格的数据

'''精准获取某一单元格的数据'''
print(worksheet.cell_value(1,3))
print(worksheet.cell(0,3).value)

7.个人学习笔记

在这里插入图片描述

😁

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值