Python使用xlrd和xlwt實(shí)現(xiàn)自動(dòng)化操作Excel
一、前言介紹
xlrd:可以對(duì)xlsx、xls、xlsm文件進(jìn)行讀操作且效率高。
xlwt:主要對(duì)xls文件進(jìn)行寫操作且效率高,但是不能執(zhí)行xlsx文件。
xlrd是用來(lái)從Excel中讀寫數(shù)據(jù)的,但通常只用它進(jìn)行讀操作,寫操作會(huì)相對(duì)于專門寫入的模塊麻煩一些。
xlwt只能對(duì)Excel進(jìn)行寫操作。xlwt和xlrd不光名字像,連很多函數(shù)和操作格式也是完全相同。
二、安裝
在命令行或者終端中使用pip安裝:
pip install Xlrd pip install xlwt


三、xlrd常用操作
用xlrd進(jìn)行讀取比較方便,流程和手動(dòng)操作Excel一樣,打開(kāi)工作簿(Workbook),選擇工作表(sheets),然后操作單元格(cell)。
1、打開(kāi)Excel
import xlrd df = xlrd.open_workbook(name)
導(dǎo)入模塊后使用
open_workbook()函數(shù)來(lái)讀取指定的一個(gè)工作簿對(duì)象。這里參數(shù)name是Excel文件名字,一般使用的是相對(duì)路徑的名字。
2、查看工作簿中所有sheet
df.sheet_names()
讀取文件,便可得到以列表形式嵌字符串的值。
3、選擇一個(gè)工作表
table=df.sheets()[0]
table=df.sheet_by_index(0)
table=df.sheet_by_name('name')第一行:獲取第一個(gè)工作表,寫法是根據(jù)內(nèi)置的列表格式來(lái)選取的。
第二行:通過(guò)索引獲取第一個(gè)工作表,這里的索引與
pandas中DataFrame的index索引類似,只不過(guò)對(duì)象換成了工作表。第三行:通過(guò)表的名稱選擇工作表。
4、獲取表格的行數(shù)、列數(shù)
row=table.nrows col=table.ncols
這里不需要在函數(shù)后面加小括號(hào)
5、獲取整行和整列的值
table.row_values(num1) table.column_values(num2)
6、通過(guò)循環(huán)讀取表格的所有行
for i in range(table.nrows): print (table.row_values(i))
7、獲取單元格的值
cell1=table.row(0)[0].value cell1=table.cell(0,0).value cell1=table.col(0)[0].value
- 第一行:獲取單元格值的方式是通過(guò)調(diào)取指定行數(shù)據(jù)進(jìn)行篩選。
- 第二行:是以二維的形式獲取,即(第i行,第j列)形式。
- 第三行:與第一行類似是通過(guò)列索引調(diào)用。
四、xlwt常用操作
1、新建Excel文件
import xlwt df2 = xlwt.Workbook()
2、新建工作表
table2=df2.add_sheet('name') #name是工作表的名稱3、寫入數(shù)據(jù)到指定單元格
table2.write(0,0,'Python') #前兩個(gè)參數(shù)對(duì)應(yīng)(第i行,第j列),代表的是單元格的位置。第三個(gè)參數(shù)是要寫的值(可以是字符串、數(shù)字)
4、保存文件
df2.save('data2.xls')PS:xlwt僅支持.xls的文件格式輸出。
五、綜合x(chóng)lrd、xlwt讀寫Excel
?1、讀
import xlrd
# 1、打開(kāi)工作本workbook
xlsx = xlrd.open_workbook(r'.\t1.xlsx')
# 2、打開(kāi)需要操作的表sheet
table = xlsx.sheet_by_index(0)
# table = xlsx.sheet_by_name('t1')
# 3、讀取指定單元格的數(shù)據(jù)
print(table.cell_value(1,1))
print(table.cell(1,1).value)
print(table.row(1)[1].value)2、寫
import xlwt
# 1、新建一個(gè)工作本
new_workbook = xlwt.Workbook()
# 2、為這個(gè)工作本中添加一個(gè)工作表
worksheet = new_workbook.add_sheet('new_test')
# 3、向指定單元格寫入內(nèi)容
worksheet.write(0,0,'nt')
# 4、保存
new_workbook.save('./nt.xls')到此這篇關(guān)于Python使用xlrd和xlwt實(shí)現(xiàn)自動(dòng)化操作Excel的文章就介紹到這了,更多相關(guān)Python操作Excel內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python中的copy()函數(shù)詳解(list,array)
這篇文章主要介紹了Python中的copy()函數(shù)詳解(list,array),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
Python實(shí)現(xiàn)簡(jiǎn)單的"導(dǎo)彈" 自動(dòng)追蹤原理解析
這篇文章主要介紹了Python實(shí)現(xiàn)簡(jiǎn)單的"導(dǎo)彈" 自動(dòng)追蹤原理解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-03-03
Python字符串轉(zhuǎn)換成浮點(diǎn)數(shù)函數(shù)分享
本文給大家分享的是一則使用Python實(shí)現(xiàn)字符串轉(zhuǎn)換成浮點(diǎn)數(shù)的代碼,主要是使用map和reduce方法來(lái)實(shí)現(xiàn),有需要的小伙伴可以參考下。2015-07-07
Python實(shí)現(xiàn)連接postgresql數(shù)據(jù)庫(kù)的方法分析
這篇文章主要介紹了Python實(shí)現(xiàn)連接postgresql數(shù)據(jù)庫(kù)的方法,結(jié)合實(shí)例形式分析了Python基于psycopg2和python3-postgresql鏈接postgresql數(shù)據(jù)庫(kù)的相關(guān)操作技巧,需要的朋友可以參考下2017-12-12
for循環(huán)在Python中的工作原理詳細(xì)
for...in 是Python程序員使用最多的語(yǔ)句,for 循環(huán)用于迭代容器對(duì)象中的元素,這些對(duì)象可以是列表、元組、字典、集合、文件,甚至可以是自定義類或者函數(shù),下面小編將舉例說(shuō)明,需要的朋友可以參考下2021-10-10
Python基礎(chǔ)學(xué)習(xí)之深淺拷貝問(wèn)題及遞歸函數(shù)練習(xí)
在實(shí)際工作中,經(jīng)常涉及到數(shù)據(jù)的傳遞。這篇文章主要為大家介紹了Python的一些基礎(chǔ)學(xué)習(xí):深拷貝與淺拷貝問(wèn)題、遞歸函數(shù)的練習(xí),需要的朋友可以參考一下2021-12-12

