注:该学习笔记是根据曾志贤老师编写的《从Excel到Python,用Python轻松处理Excel数据》所学习整理的笔记。
模块(module):模块是一个Python文件,拓展名为.py。
包(package):包是模块之上的概念,为了方便管理.py模块文件,可以进行打包。包其实就是文件夹,不过该文件夹下有名称为_init_.py的文件。
库(library):在Python中,具有默写功能的模块和包都可以被称为库。
xlrd库主要用于读取Excel的.xls和.xlsx文件。最新版本的xlrd库只支持.xls文件,1.X版本支持.xls与.xlsx文件。
import xlrd #使用import函数导入xlrd库
import xlrd as xld #使用别称xld代替xlrd
from xlrd import open_workbook as owk
#使用from函数,仅导入xlrd库中的open_workbook函数,并起别称为owk。
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.sheet()[1] #使用索引读取工作表的方法2
ws3=wb.sheet_by_name('sheet3') #使用工作表名称读取工作表
ws4=xlrd.open_workbook(r'123.xls').sheet_by_name('sheet4') #直接通过工作簿读取指定名称的工作表
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库只能新建.xls后缀工作簿,不能保存为.xlsx后缀的工作簿。
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库主要用于连接xlrd库与xlwt库,将可以同时具有读取、写入、保存的能力。需要注意的是,安装xlutils库前必须已经安装了xlrd库和xlwt库,否则将会没有意义。
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文件。