點擊讓手機旋轉,
即可自動調整表格格式
進行觀看
向上滑動查看更多
以後會持續的為大家提供【免費]、【高質量】的全球技術行業資訊;前沿IT技術分享;一線大廠招聘、內推與筆面試準備等服務。為了方便大家下載,可以關注我們的公眾號:
回覆:【python】、【Java】、【sql】、【面試】
即可免費自助獲取對應資料下載連結。
好了,進入正題,我們來看今天的【一文搞定】使用python-openpyxl庫讀寫Excel表格(增刪改查操作)
包括內容有:
一、前言
二、安裝openpyxl
三、openpyxl的使用
1、創建Excel文件
2、加載已存在的Excel文件
3、創建sheet
4、判斷某個sheet是否存在
5、遍歷所有Sheet的名稱
6、寫入單元格
7、獲取單元格的各個屬性值
8、遍歷單元格
9、最大行最大列
10、刪除行或列
11、設置字體
12、填充單元格顏色
13、設置行高與列寬
最近需要做個小工具,可以通過python來讀寫Excel,實現增刪改查操作。以前用的是xlrd和xlwt這兩個python庫,今天我要講的是openpyxl庫,我覺得openpyxl比xlrd和xlwt更強大更好用,話不多說,開始吧。
可以直接通過命令行安裝
如果你是內網環境,則可以先在外網下載openpyxl庫然後轉到內網再安裝。
openpyxl下載地址:https://pypi.org/project/openpyxl/#files
不過因為openpyxl還依賴了et_xmlfile庫,所以你還得下載個et_xmlfile。
如果是用命令行pip install openpyxl,則會自動下載依賴。et_xmlfile下載地址:https://pypi.org/project/et-xmlfile/#files
安裝完畢後,在python中執行import openpyxl如果沒有報錯,則說明安裝成功了。
演示代碼:
import openpyxl
book = openpyxl.Workbook()book.save(u'我的表格.xlsx')
運行效果如下,生成了一個excel表格。
上面已經創建了一個表格,我們可以直接加載它。
演示代碼:import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')book.close()
演示代碼:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')sheet = book.create_sheet('我的Sheet')book.save(u'我的表格.xlsx')book.close()運行效果如下:
演示代碼:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')if None != book[u'我的Sheet']: print('我的Sheet 存在')book.close()
運行結果:
演示代碼:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')for sheet_name in book.sheetnames: print(sheet_name)book.close()運行結果:
演示代碼:
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 = '林新發'book.save(u'我的表格.xlsx')book.close()運行效果
為了演示,我在我名字那裡加個批註:
演示代碼:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')sheet = book['Sheet']cell = sheet.cell(3,1)print('value:%s'%cell.value)print('row: %d, col: %d'%(cell.row, cell.column))print('column_letter: %s'%cell.column_letter)print('coordinate: %s'%cell.coordinate)print('data_type: %s'%cell.data_type)print('encoding: %s'%cell.encoding)print('style: %s'%cell.style)print('comment: %s'%cell.comment)book.close()
運行結果:value:林新發row: 3, col: 1column_letter: Acoordinate: A3data_type: sencoding: utf-8style: 常規comment: Comment: linxinfa:多才多藝 by linxinfa
為了演示,我加多一寫數據:
一行一行遍歷,演示代碼:
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()運行結果:
<Cell 'Sheet'.A1> name<Cell 'Sheet'.B1> profession<Cell 'Sheet'.C1> hobby<Cell 'Sheet'.A2> 姓名<Cell 'Sheet'.B2> 職業<Cell 'Sheet'.C2> 愛好<Cell 'Sheet'.A3> 林新發<Cell 'Sheet'.B3> Unity3D遊戲開發工程師<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()運行結果:
<Cell 'Sheet'.A1> name<Cell 'Sheet'.A2> 姓名<Cell 'Sheet'.A3> 林新發<Cell 'Sheet'.B1> profession<Cell 'Sheet'.B2> 職業<Cell 'Sheet'.B3> Unity3D遊戲開發工程師<Cell 'Sheet'.C1> hobby<Cell 'Sheet'.C2> 愛好<Cell 'Sheet'.C3> 吉他、鋼琴、畫畫、貓貓、寫博客
為了演示,再加點數據。
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()運行結果:
max_row: 4, max_column: 3
為了演示,我再加多些數據。
演示代碼:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')sheet = book['Sheet']sheet.delete_rows(5)sheet.delete_cols(4)book.save(u'我的表格.xlsx')book.close()運行效果:
演示代碼:
import openpyxlfrom 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()運行效果:
填充顏色之前
演示代碼:
import openpyxlfrom openpyxl.styles import PatternFill
book = openpyxl.load_workbook(u'我的表格.xlsx')sheet = book['Sheet']cell = sheet.cell(4,2)cell.fill = PatternFill('solid',fgColor='FFBB00')book.save(u'我的表格.xlsx')book.close()
運行效果:
為了演示,我先把行高和列寬改成這樣:
演示代碼:
import openpyxlfrom openpyxl.utils import get_column_letter
book = openpyxl.load_workbook(u'我的表格.xlsx')sheet = book['Sheet']row_4 = sheet.row_dimensions[4]row_4.height = 15col_2 = sheet.column_dimensions[get_column_letter(2)]col_2.width = 40book.save(u'我的表格.xlsx')book.close()
執行效果:注意,上面我用到了一個get_column_letter方法,因為column_dimensions需要的是字母參數,所以我們不能直接傳2,通過get_column_letter(2)即可得到"B",也就是第2列。
如果要反過來,通過字母逆算出數字,則用column_index_from_string方法,例:
from openpyxl.utils import column_index_from_stringprint(column_index_from_string('B'))版權聲明:本文為博主原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處連結和本聲明。
本文連結:https://blog.csdn.net/muyashui/article/details/116309278
更多內容,歡迎標⭐公眾號,每日更新ing
最後,感謝大家對樂學偶得的關注與支持~
歡迎更多的小夥伴加入樂學偶得大家庭~
添加樂學偶得校花小姐姐,自助領取禮包與自助入群~
輸入【相應資料編號與想加入的群】,自助領取資料與進入學習交流群
比如想進入自動辦公相關群,直接@小助手 【自動辦公群】即可自助進群
(純交流,無廣告,群內福利持續更新,免費領取)
點擊左下角【閱讀原文】查看【樂學偶得】更多乾貨