Python中openpyxl庫讀寫表格的操作是什么
Admin 2022-06-27 群英技術(shù)資訊 907 次瀏覽
這篇文章主要介紹了Python中openpyxl庫讀寫表格的操作是什么相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Python中openpyxl庫讀寫表格的操作是什么文章都會(huì)有所收獲,下面我們一起來看看吧。嗨,大家好,我是新發(fā)。
最近需要做個(gè)小工具,可以通過python來讀寫Excel,實(shí)現(xiàn)增刪改查操作。以前用的是xlrd和xlwt這兩個(gè)python庫,今天我要講的是openpyxl庫,我覺得openpyxl比xlrd和xlwt更強(qiáng)大更好用,話不多說,開始吧。
可以直接通過命令行安裝
pip install openpyxl

如果你是內(nèi)網(wǎng)環(huán)境,則可以先在外網(wǎng)下載openpyxl庫然后轉(zhuǎn)到內(nèi)網(wǎng)再安裝。
openpyxl下載地址:https://pypi.org/project/openpyxl/#files

不過如果你下載了openpyxl,因?yàn)?code>openpyxl還依賴了et_xmlfile庫,所以你還得下載個(gè)et_xmlfile。
如果是用命令行
pip install openpyxl,則會(huì)自動(dòng)下載依賴。
et_xmlfile下載地址:https://pypi.org/project/et-xmlfile/#files

安裝完畢后,在python中執(zhí)行import openpyxl如果沒有報(bào)錯(cuò),則說明安裝成功了。

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的名稱
演示代碼:
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、寫入單元格
演示代碼:
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、遍歷單元格
為了演示,我加多一寫數(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> 愛好
<Cell 'Sheet'.A3> 林新發(fā)
<Cell 'Sheet'.B3> Unity3D游戲開發(fā)工程師
<Cell 'Sheet'.C3> 吉他、鋼琴、畫畫、貓貓、寫博客
一列一列遍歷,演示代碼:
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游戲開發(fā)工程師
<Cell 'Sheet'.C1> hobby
<Cell 'Sheet'.C2> 愛好
<Cell 'Sheet'.C3> 吉他、鋼琴、畫畫、貓貓、寫博客
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、刪除行或列
為了演示,我再加多寫數(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,通過get_column_letter(2)即可得到"B",也就是第2列。
如果要反過來,通過字母逆算出數(shù)字,則用column_index_from_string方法,例:
from openpyxl.utils import column_index_from_string
print(column_index_from_string('B'))
# 輸出2
完畢。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:[email protected]進(jìn)行舉報(bào),并提供相關(guān)證據(jù),查實(shí)之后,將立刻刪除涉嫌侵權(quán)內(nèi)容。
猜你喜歡
這篇文章主要為大家介紹了SpringBoot整合VUE?EasyExcel實(shí)現(xiàn)數(shù)據(jù)導(dǎo)入導(dǎo)出,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
在編寫代碼的時(shí)候,經(jīng)常會(huì)出現(xiàn)寫的代碼存在一些問題,但是比較難以發(fā)現(xiàn)具體存在的問題在哪里,需要將帶代碼恢復(fù)到指定的版本,下面這篇文章主要給大家介紹了關(guān)于pycharm中代碼回滾到指定版本的兩種實(shí)現(xiàn)方法,需要的朋友可以參考下
對(duì)于掃雷游戲相信大家應(yīng)該都不陌生吧,掃雷游戲可以說是很經(jīng)典的游戲了,之前我們了解了使用介紹實(shí)現(xiàn)掃雷游戲,這篇文章我們就來嘗試使用python做一個(gè)掃雷游戲,感興趣的朋友就接著往下看吧。
時(shí)間處理是我們?nèi)粘i_發(fā)中最最常見的需求,例如:獲取當(dāng)前datetime、獲取當(dāng)天date、獲取明天 前N天、獲取當(dāng)天開始和結(jié)束時(shí)間(00:00:00 23:
這篇文章主要介紹了python中的編碼和解碼及\x和\u問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
推薦內(nèi)容
相關(guān)標(biāo)簽
成為群英會(huì)員,開啟智能安全云計(jì)算之旅
立即注冊(cè)關(guān)注或聯(lián)系群英網(wǎng)絡(luò)
7x24小時(shí)售前:400-678-4567
7x24小時(shí)售后:0668-2555666
24小時(shí)QQ客服
群英微信公眾號(hào)
CNNIC域名投訴舉報(bào)處理平臺(tái)
服務(wù)電話:010-58813000
服務(wù)郵箱:[email protected]
投訴與建議:0668-2555555
Copyright ? QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版權(quán)所有
增值電信經(jīng)營許可證 : B1.B2-20140078 ICP核準(zhǔn)(ICP備案)粵ICP備09006778號(hào) 域名注冊(cè)商資質(zhì) 粵 D3.1-20240008