Python入门:对Excel数据处理的学习笔记【第二章】xlrd、xlwt、xlutils库的基本操作学习

注:该学习笔记是根据曾志贤老师编写的《从Excel到Python,用Python轻松处理Excel数据》所学习整理的笔记。

第二章 xlrd、xlwt、xlutils库的基本操作学习

一、什么是模块、包、库

模块(module):模块是一个Python文件,拓展名为.py。
包(package):包是模块之上的概念,为了方便管理.py模块文件,可以进行打包。包其实就是文件夹,不过该文件夹下有名称为_init_.py的文件。
库(library):在Python中,具有默写功能的模块和包都可以被称为库。

二、xlrd库

xlrd库主要用于读取Excel的.xls和.xlsx文件。最新版本的xlrd库只支持.xls文件,1.X版本支持.xls与.xlsx文件。

1、导入xlrd库的方法

import xlrd #使用import函数导入xlrd库
import xlrd as xld #使用别称xld代替xlrd
from xlrd import open_workbook as owk 
#使用from函数,仅导入xlrd库中的open_workbook函数,并起别称为owk。

2、读取Excel工作簿、工作表

import xlrd #导入xlrd库
wb=xlrd.open_workbook(r'123.xls') #读取123.xls工作簿
all_ws1=wb.sheets() #读取该工作簿的所有工作表
all_ws1_name=wb.sheet_names() #读取该工作簿的所有工作表的名称
ws1=wb.sheet_by_index(0) #使用索引读取工作表的方法1
ws2=wb.sheets()[1] #使用索引读取工作表的方法2
ws3=wb.sheet_by_name('sheet3') #使用工作表名称读取工作表
ws4=xlrd.open_workbook(r'123.xls').sheet_by_name('sheet4') #直接通过工作簿读取指定名称的工作表

3、读取Excel行、列单元格信息

import xlrd #导入xlrd库
#-----------获取指定工作簿和工作表---------------------
wb=xlrd.open_workbook(r'123.xls') #读取123.xls工作簿
ws=wb.sheet_by_name('sheet1') #读取该工作簿下的名为sheet1工作表
#-----------获取最大行、列----------------------------
row_count=ws.nrows #返回该工作表已使用的行数(最大行数)
col_count=ws.ncols #返回该工作表已使用的列数(最大列数)
#-----------获取整行、整列的对象或值-------------------
row_row=ws.row(1) #返回该工作表中指定行已使用的单元格对象(意思为读取了指定行的所有有内容的对象)
row_val=ws.row_values(1) #返回该工作表中指定行已使用的单元格的值
col_col=ws.col(1) #返回该工作表中指定列已使用的单元格对象(意思为读取了指定列的所有有内容的对象)
col_val=ws.col_values(1) #返回该工作表中指定列已使用的单元格的值
#-----------获取单元格对象或值------------------------
cell_cell=ws.cell(1,1) #返回该工作表中指定行、列的单元格对象
cell_val=ws.cell_value(1,1) #返回该工作表中指定行、列的单元格对象的值

三、xlwt库

xlwt库主要用于创建新的工作簿、工作表以及将数据写入单元格的功能。但xlwt库只能新建.xls后缀工作簿,不能保存为.xlsx后缀的工作簿。

1、新建工作簿、工作表、将数据写入单元格

import xlwt
nwb=xlwt.workbook('utf-8') #新建工作簿,以utf-8的方式进行编码(utf-8为中文编码方式)
nws=nwb.add_sheet('sheet1') #在该工作簿中新建工作表,命名为“sheet1”
nws.write(0,0,'学习:第二章') #在该工作表中指定的行、列单元格写入值“学习:第二章”,write(行,列,值)
nwb.save('第二章学习.xls') #保存新建的工作簿,命名为“第二章学习”

四、xlutils库

xlutils库主要用于连接xlrd库与xlwt库,将可以同时具有读取、写入、保存的能力。需要注意的是,安装xlutils库前必须已经安装了xlrd库和xlwt库,否则将会没有意义。

1、修改工作簿、工作表、单元格

import xlrd
from xlutils.copy import copy #导入xlutils库中的copy模块中的copy函数
wb=xlrd.open_workbook('第二章学习.xls') #读取工作簿
nwb=copy(wb) #复制工作簿
ws1=nwb.get_sheet(0) #用索引号读取该工作簿中的工作表
ws2=nwb.get_sheet('sheet1') #用工作表名读取工作表
ws3=nwb.add_sheet('sheet2') #在工作簿中新建工作表命名为“sheet2”
ws3.write(0,0,'第二章学习') #写入字符串到指定单元格
ws3.write(0,1,520) #写入数字到指定单元格
nwb.save('第二章学习-1.xls') #保存工作簿

注意事项:
from xlutils.copy import copy 如果直接导入xlutils库的写法为 xlutils.copy.copy 。而只导入copy函数将只需要写copy就可以了。
由于执行了copy(wb)的步骤,将不需要再用import导入xlwt库,但必须要已经安装的有,否则将会报错。
nwb.save(‘第二章学习-1.xls’) 表示为另存为“第二章学习-1.xls”。如果使用原本的名字“第二章学习.xls”将会覆盖保存,但必须确保原名字的Excel工作簿处于关闭的状态。
不能保存为.xlsx文件,只能保存为.xls文件。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MeJonKing

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值