主頁(yè) > 知識(shí)庫(kù) > python使用openpyxl庫(kù)讀寫(xiě)Excel表格的方法(增刪改查操作)

python使用openpyxl庫(kù)讀寫(xiě)Excel表格的方法(增刪改查操作)

熱門(mén)標(biāo)簽:外呼不封號(hào)系統(tǒng) 電信營(yíng)業(yè)廳400電話申請(qǐng) 蘇州電銷(xiāo)機(jī)器人十大排行榜 幫人做地圖標(biāo)注收費(fèi)算詐騙嗎 遼寧400電話辦理多少錢(qián) 悟空智電銷(xiāo)機(jī)器人6 荊州云電銷(xiāo)機(jī)器人供應(yīng)商 溫州旅游地圖標(biāo)注 江蘇房產(chǎn)電銷(xiāo)機(jī)器人廠家

一、前言

嗨,大家好,我是新發(fā)。
最近需要做個(gè)小工具,可以通過(guò)python來(lái)讀寫(xiě)Excel,實(shí)現(xiàn)增刪改查操作。以前用的是xlrdxlwt這兩個(gè)python庫(kù),今天我要講的是openpyxl庫(kù),我覺(jué)得openpyxlxlrdxlwt更強(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還依賴了et_xmlfile庫(kù),所以你還得下載個(gè)et_xmlfile。

如果是用命令行pip install openpyxl,則會(huì)自動(dòng)下載依賴。

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)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python 辦公自動(dòng)化——基于pyqt5和openpyxl統(tǒng)計(jì)符合要求的名單
  • Python Excel處理庫(kù)openpyxl詳解
  • Python利器openpyxl之操作excel表格
  • Python離線安裝openpyxl模塊的步驟
  • 解決python 使用openpyxl讀寫(xiě)大文件的坑
  • Python openpyxl 無(wú)法保存文件的解決方案
  • python openpyxl 帶格式復(fù)制表格的實(shí)現(xiàn)
  • python 使用openpyxl讀取excel數(shù)據(jù)
  • python openpyxl的使用方法

標(biāo)簽:喀什 黃山 景德鎮(zhèn) 欽州 三沙 濟(jì)南 臺(tái)灣 宿遷

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python使用openpyxl庫(kù)讀寫(xiě)Excel表格的方法(增刪改查操作)》,本文關(guān)鍵詞  python,使用,openpyxl,庫(kù),讀寫(xiě),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python使用openpyxl庫(kù)讀寫(xiě)Excel表格的方法(增刪改查操作)》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于python使用openpyxl庫(kù)讀寫(xiě)Excel表格的方法(增刪改查操作)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章