python使用openpyxl庫(kù)讀寫(xiě)Excel表格的方法(增刪改查操作)
一、前言
嗨,大家好,我是新發(fā)。
最近需要做個(gè)小工具,可以通過(guò)python
來(lái)讀寫(xiě)Excel
,實(shí)現(xiàn)增刪改查操作。以前用的是xlrd
和xlwt
這兩個(gè)python
庫(kù),今天我要講的是openpyxl
庫(kù),我覺(jué)得openpyxl
比xlrd
和xlwt
更強(qiáng)大更好用,話不多說(shuō),開(kāi)始吧。
二、安裝openpyxl
可以直接通過(guò)命令行安裝
pip install openpyxl
如果你是內(nèi)網(wǎng)環(huán)境,則可以先在外網(wǎng)下載openpyxl
庫(kù)然后轉(zhuǎn)到內(nèi)網(wǎng)再安裝。
openpyxl
下載地址:https://pypi.org/project/openpyxl/#files
不過(guò)如果你下載了openpyxl
,因?yàn)?code>openpyxl還依賴(lài)了et_xmlfile
庫(kù),所以你還得下載個(gè)et_xmlfile
。
如果是用命令行
pip install openpyxl
,則會(huì)自動(dòng)下載依賴(lài)。
et_xmlfile
下載地址:https://pypi.org/project/et-xmlfile/#files
安裝完畢后,在python
中執(zhí)行import openpyxl
如果沒(méi)有報(bào)錯(cuò),則說(shuō)明安裝成功了。
三、openpyxl的使用
1、創(chuàng)建Excel文件
演示代碼:
import openpyxl book = openpyxl.Workbook() book.save(u'我的表格.xlsx')
運(yùn)行效果如下,生成了一個(gè)excel
表格。
2、加載已存在的Excel文件
上面已經(jīng)創(chuàng)建了一個(gè)表格,我們可以直接加載它。
演示代碼:
import openpyxl book = openpyxl.load_workbook(u'我的表格.xlsx') # ... book.close()
3、創(chuàng)建sheet
演示代碼:
import openpyxl book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book.create_sheet('我的Sheet') book.save(u'我的表格.xlsx') book.close()
運(yùn)行效果如下:
4、判斷某個(gè)sheet是否存在
演示代碼:
import openpyxl book = openpyxl.load_workbook(u'我的表格.xlsx') if None != book[u'我的Sheet']: print('我的Sheet 存在') book.close()
運(yùn)行結(jié)果:
我的Sheet 存在
5、遍歷所有Sheet的名稱(chēng)
演示代碼:
import openpyxl book = openpyxl.load_workbook(u'我的表格.xlsx') for sheet_name in book.sheetnames: print(sheet_name) book.close()
運(yùn)行結(jié)果:
Sheet
我的Sheet
6、寫(xiě)入單元格
演示代碼:
import openpyxl book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book['Sheet'] sheet.cell(1,1).value = 'name' sheet.cell(2,1).value = '姓名' sheet.cell(3,1).value = '林新發(fā)' book.save(u'我的表格.xlsx') book.close()
運(yùn)行效果
7、獲取單元格的各個(gè)屬性值
為了演示,我在我名字那里加個(gè)批注:
演示代碼:
import openpyxl book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book['Sheet'] cell = sheet.cell(3,1) # 獲取單元格的值 print('value:%s'%cell.value) # 獲取行號(hào)、列號(hào) print('row: %d, col: %d'%(cell.row, cell.column)) # 獲取列名 print('column_letter: %s'%cell.column_letter) # 單元格的坐標(biāo) print('coordinate: %s'%cell.coordinate) # 單元格數(shù)據(jù)格式,n: 數(shù)字,s:字符串,d: 日期 print('data_type: %s'%cell.data_type) # 單元格編碼格式 print('encoding: %s'%cell.encoding) # 單元格樣式 print('style: %s'%cell.style) # 單元格批注 print('comment: %s'%cell.comment) book.close()
運(yùn)行結(jié)果:
value:林新發(fā)
row: 3, col: 1
column_letter: A
coordinate: A3
data_type: s
encoding: utf-8
style: 常規(guī)
comment: Comment: linxinfa:
多才多藝 by linxinfa
8、遍歷單元格
為了演示,我加多一寫(xiě)數(shù)據(jù):
一行一行遍歷,演示代碼:
import openpyxl book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book['Sheet'] # 一行一行遍歷 for one_row in sheet.rows: for cell in one_row: print(cell, cell.value) book.close()
運(yùn)行結(jié)果:
<Cell 'Sheet'.A1> name
<Cell 'Sheet'.B1> profession
<Cell 'Sheet'.C1> hobby
<Cell 'Sheet'.A2> 姓名
<Cell 'Sheet'.B2> 職業(yè)
<Cell 'Sheet'.C2> 愛(ài)好
<Cell 'Sheet'.A3> 林新發(fā)
<Cell 'Sheet'.B3> Unity3D游戲開(kāi)發(fā)工程師
<Cell 'Sheet'.C3> 吉他、鋼琴、畫(huà)畫(huà)、貓貓、寫(xiě)博客
一列一列遍歷,演示代碼:
import openpyxl book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book['Sheet'] # 一列一列遍歷 for one_col in sheet.columns: for cell in one_col: print(cell, cell.value) book.close()
運(yùn)行結(jié)果:
<Cell 'Sheet'.A1> name
<Cell 'Sheet'.A2> 姓名
<Cell 'Sheet'.A3> 林新發(fā)
<Cell 'Sheet'.B1> profession
<Cell 'Sheet'.B2> 職業(yè)
<Cell 'Sheet'.B3> Unity3D游戲開(kāi)發(fā)工程師
<Cell 'Sheet'.C1> hobby
<Cell 'Sheet'.C2> 愛(ài)好
<Cell 'Sheet'.C3> 吉他、鋼琴、畫(huà)畫(huà)、貓貓、寫(xiě)博客
9、最大行最大列
為了演示,再加點(diǎn)數(shù)據(jù)。
import openpyxl book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book['Sheet'] print('max_row: %d, max_column: %d'%(sheet.max_row, sheet.max_column)) book.close()
運(yùn)行結(jié)果:
max_row: 4, max_column: 3
10、刪除行或列
為了演示,我再加多寫(xiě)數(shù)據(jù)。
演示代碼:
import openpyxl book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book['Sheet'] # 刪除第5行 sheet.delete_rows(5) # 刪除第4列 sheet.delete_cols(4) book.save(u'我的表格.xlsx') book.close()
運(yùn)行效果:
11、設(shè)置字體
演示代碼:
import openpyxl from openpyxl.styles import Font book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book['Sheet'] cell = sheet.cell(4,1) cell.font = Font(name='微軟雅黑',size=18,color='00FFCC99',b=True,i=False) book.save(u'我的表格.xlsx') book.close()
運(yùn)行效果:
12、填充單元格顏色
填充顏色之前
演示代碼:
import openpyxl from openpyxl.styles import PatternFill book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book['Sheet'] cell = sheet.cell(4,2) # 設(shè)置填充色 cell.fill = PatternFill('solid',fgColor='FFBB00') book.save(u'我的表格.xlsx') book.close()
運(yùn)行效果:
13、設(shè)置行高與列寬
為了演示,我先把行高和列寬改成這樣:
演示代碼:
import openpyxl from openpyxl.utils import get_column_letter book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book['Sheet'] # 取第4行 row_4 = sheet.row_dimensions[4] # 設(shè)置行高 row_4.height = 15 # 取第2列 col_2 = sheet.column_dimensions[get_column_letter(2)] # 設(shè)置列寬 col_2.width = 40 book.save(u'我的表格.xlsx') book.close()
執(zhí)行效果:
注意,上面我用到了一個(gè)get_column_letter
方法,因?yàn)?code>column_dimensions需要的是字母參數(shù),所以我們不能直接傳2
,通過(guò)get_column_letter(2)
即可得到"B"
,也就是第2列
。
如果要反過(guò)來(lái),通過(guò)字母逆算出數(shù)字,則用column_index_from_string
方法,例:
from openpyxl.utils import column_index_from_string print(column_index_from_string('B')) # 輸出2
四、結(jié)束語(yǔ)
完畢。
博主是Unity3D游戲工程師
,喜歡Unity
的同學(xué),不要忘記點(diǎn)擊關(guān)注,如果有什么Unity
相關(guān)的技術(shù)難題,也歡迎留言或私信~
到此這篇關(guān)于python使用openpyxl庫(kù)讀寫(xiě)Excel表格的方法(增刪改查操作)的文章就介紹到這了,更多相關(guān)python讀寫(xiě)Excel表格內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用Python中的mock庫(kù)對(duì)Python代碼進(jìn)行模擬測(cè)試
這篇文章主要介紹了利用Python中的mock庫(kù)對(duì)Python代碼進(jìn)行模擬測(cè)試,mock庫(kù)自從Python3.3依賴(lài)成為了Python的內(nèi)置庫(kù),本文也等于介紹了該庫(kù)的用法,需要的朋友可以參考下2015-04-04Python Charles抓包配置實(shí)現(xiàn)流程圖解
這篇文章主要介紹了Python Charles抓包實(shí)現(xiàn)流程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09python+opencv實(shí)現(xiàn)堆疊圖片
這篇文章主要為大家詳細(xì)介紹了python+opencv實(shí)現(xiàn)堆疊圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04TensorFlow和keras中GPU使用的設(shè)置操作
這篇文章主要介紹了TensorFlow和keras中GPU使用的設(shè)置操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05Python中的簡(jiǎn)寫(xiě)操作(for、if簡(jiǎn)寫(xiě)、匿名函數(shù))
這篇文章主要介紹了Python中的簡(jiǎn)寫(xiě)操作(for、if簡(jiǎn)寫(xiě)、匿名函數(shù)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07Python opencv缺陷檢測(cè)的實(shí)現(xiàn)及問(wèn)題解決
這篇文章主要介紹了Python opencv缺陷檢測(cè)的實(shí)現(xiàn)及問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04