电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:4日期:2022-06-20 16:00:14
一、前言

嗨,大家好,我是新發。最近需要做個小工具,可以通過python來讀寫Excel,實現增刪改查操作。以前用的是xlrd和xlwt這兩個python庫,今天我要講的是openpyxl庫,我覺得openpyxl比xlrd和xlwt更強大更好用,話不多說,開始吧。

二、安裝openpyxl

可以直接通過命令行安裝

pip install openpyxl

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

如果你是內網環境,則可以先在外網下載openpyxl庫然后轉到內網再安裝。openpyxl下載地址:https://pypi.org/project/openpyxl/#files

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

不過如果你下載了openpyxl,因為openpyxl還依賴了et_xmlfile庫,所以你還得下載個et_xmlfile。

如果是用命令行pip install openpyxl,則會自動下載依賴。

et_xmlfile下載地址:https://pypi.org/project/et-xmlfile/#files

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

安裝完畢后,在python中執行import openpyxl如果沒有報錯,則說明安裝成功了。

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

三、openpyxl的使用

1、創建Excel文件

演示代碼:

import openpyxlbook = openpyxl.Workbook()book.save(u’我的表格.xlsx’)

運行效果如下,生成了一個excel表格。

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

2、加載已存在的Excel文件

上面已經創建了一個表格,我們可以直接加載它。演示代碼:

import openpyxlbook = openpyxl.load_workbook(u’我的表格.xlsx’)# ... book.close()

3、創建sheet

演示代碼:

import openpyxlbook = openpyxl.load_workbook(u’我的表格.xlsx’)sheet = book.create_sheet(’我的Sheet’)book.save(u’我的表格.xlsx’)book.close()

運行效果如下:

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

4、判斷某個sheet是否存在

演示代碼:

import openpyxlbook = openpyxl.load_workbook(u’我的表格.xlsx’)if None != book[u’我的Sheet’]: print(’我的Sheet 存在’)book.close()

運行結果:

我的Sheet 存在

5、遍歷所有Sheet的名稱

演示代碼:

import openpyxlbook = openpyxl.load_workbook(u’我的表格.xlsx’)for sheet_name in book.sheetnames: print(sheet_name)book.close()

運行結果:

Sheet我的Sheet

6、寫入單元格

演示代碼:

import openpyxlbook = 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()

運行效果

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

7、獲取單元格的各個屬性值

為了演示,我在我名字那里加個批注:

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

演示代碼:

import openpyxlbook = 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)# 單元格數據格式,n: 數字,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()

運行結果:

value:林新發row: 3, col: 1column_letter: Acoordinate: A3data_type: sencoding: utf-8style: 常規comment: Comment: linxinfa:多才多藝 by linxinfa

8、遍歷單元格

為了演示,我加多一寫數據:

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

一行一行遍歷,演示代碼:

import openpyxlbook = 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 openpyxlbook = 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> 吉他、鋼琴、畫畫、貓貓、寫博客

9、最大行最大列

為了演示,再加點數據。

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

import openpyxlbook = 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

10、刪除行或列

為了演示,我再加多寫數據。

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

演示代碼:

import openpyxlbook = openpyxl.load_workbook(u’我的表格.xlsx’)sheet = book[’Sheet’]# 刪除第5行sheet.delete_rows(5)# 刪除第4列sheet.delete_cols(4)book.save(u’我的表格.xlsx’)book.close()

運行效果:

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

11、設置字體

演示代碼:

import openpyxlfrom openpyxl.styles import Fontbook = 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()

運行效果:

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

12、填充單元格顏色

填充顏色之前

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

演示代碼:

import openpyxlfrom openpyxl.styles import PatternFillbook = 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()

運行效果:

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

13、設置行高與列寬

為了演示,我先把行高和列寬改成這樣:

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

演示代碼:

import openpyxlfrom openpyxl.utils import get_column_letterbook = openpyxl.load_workbook(u’我的表格.xlsx’)sheet = book[’Sheet’]# 取第4行row_4 = sheet.row_dimensions[4]# 設置行高row_4.height = 15# 取第2列col_2 = sheet.column_dimensions[get_column_letter(2)]# 設置列寬col_2.width = 40book.save(u’我的表格.xlsx’)book.close()

執行效果:

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

注意,上面我用到了一個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’))# 輸出2四、結束語

完畢。博主是Unity3D游戲工程師,喜歡Unity的同學,不要忘記點擊關注,如果有什么Unity相關的技術難題,也歡迎留言或私信~

到此這篇關于python使用openpyxl庫讀寫Excel表格的方法(增刪改查操作)的文章就介紹到這了,更多相關python讀寫Excel表格內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: python
相關文章:
主站蜘蛛池模板: 鑫铭东办公家具一站式定制采购-深圳办公家具厂家直销 | 武汉天安盾电子设备有限公司 - 安盾安检,武汉安检门,武汉安检机,武汉金属探测器,武汉测温安检门,武汉X光行李安检机,武汉防爆罐,武汉车底安全检查,武汉液体探测仪,武汉安检防爆设备 | 华溶溶出仪-Memmert稳定箱-上海协烁仪器科技有限公司 | 电子厂招聘_工厂招聘_普工招聘_小时工招聘信息平台-众立方招工网 | 泰兴市热钻机械有限公司-热熔钻孔机-数控热熔钻-热熔钻孔攻牙一体机 | 福建省教师资格证-福建教师资格证考试网| 钢制暖气片散热器_天津钢制暖气片_卡麦罗散热器厂家 | 热闷罐-高温罐-钢渣热闷罐-山东鑫泰鑫智能热闷罐厂家 | 蔬菜配送公司|蔬菜配送中心|食材配送|饭堂配送|食堂配送-首宏公司 | 上海小程序开发-小程序制作-上海小程序定制开发公司-微信商城小程序-上海咏熠 | 异噻唑啉酮-均三嗪-三丹油-1227-中北杀菌剂厂家 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 上海璟文空运首页_一级航空货运代理公司_机场快递当日达 | 粉末包装机,拆包机厂家,价格-上海强牛包装机械设备有限公司 | 高防护蠕动泵-多通道灌装系统-高防护蠕动泵-www.bjhuiyufluid.com慧宇伟业(北京)流体设备有限公司 | 低温柔性试验仪-土工布淤堵-沥青车辙试验仪-莱博特(天津)试验机有限公司 | 金属切削液-脱水防锈油-电火花机油-抗磨液压油-深圳市雨辰宏业科技发展有限公司 | 钢格板|镀锌钢格板|热镀锌钢格板|格栅板|钢格板|钢格栅板|热浸锌钢格板|平台钢格板|镀锌钢格栅板|热镀锌钢格栅板|平台钢格栅板|不锈钢钢格栅板 - 专业钢格板厂家 | TTCMS自助建站_网站建设_自助建站_免费网站_免费建站_天天向上旗下品牌 | IPO咨询公司-IPO上市服务-细分市场研究-龙马咨询 | led冷热冲击试验箱_LED高低温冲击试验箱_老化试验箱-爱佩百科 | 铣刨料沥青破碎机-沥青再生料设备-RAP热再生混合料破碎筛分设备 -江苏锡宝重工 | 120kv/2mA直流高压发生器-60kv/2mA-30kva/50kv工频耐压试验装置-旭明电工 | 防爆型气象站_农业气象站_校园气象站_农业四情监测系统「山东万象环境科技有限公司」 | 碳钢法兰厂家,非标法兰,定制异型,法兰生产厂家-河北九瑞管道 | 深圳货架厂家_金丽声精品货架_广东金丽声展示设备有限公司官网 | 档案密集架_电动密集架_移动密集架_辽宁档案密集架-盛隆柜业厂家现货批发销售价格公道 | 消电检公司,消电检价格,北京消电检报告-北京设施检测公司-亿杰(北京)消防工程有限公司 | 佛山商标注册_商标注册代理|专利注册申请_商标注册公司_鸿邦知识产权 | 丽陂特官网_手机信号屏蔽器_Wifi信号干扰器厂家_学校考场工厂会议室屏蔽仪 | 德国进口电锅炉_商用电热水器_壁挂炉_电采暖器_电热锅炉[德国宝] | 彭世修脚_修脚加盟_彭世修脚加盟_彭世足疗加盟_足疗加盟连锁_彭世修脚技术培训_彭世足疗 | 商标转让-购买商标专业|放心的商标交易网-蜀易标商标网 | 膜结构停车棚-自行车棚-膜结构汽车棚加工安装厂家幸福膜结构 | Brotu | 关注AI,Web3.0,VR/AR,GPT,元宇宙区块链数字产业 | 离子色谱自动进样器-青岛艾力析实验科技有限公司 | ERP企业管理系统永久免费版_在线ERP系统_OA办公_云版软件官网 | 工业雾炮机_超细雾炮_远程抑尘射雾器-世纪润德环保设备 | 双效节能浓缩器-热回流提取浓缩机组-温州市利宏机械 | 滚珠丝杆升降机_螺旋升降机_丝杠升降机-德迈传动 | 无线对讲-无线对讲系统解决方案-重庆畅博通信 |