python openpyxl的使用方法
生成新Excel
from openpyxl import Workbook from openpyxl.utils import get_column_letter wb = Workbook() dest_filename = 'empty_book.xlsx' ws1 = wb.active ws1.title = "range names" for row in range(1, 40): ws1.append(range(600)) ws2 = wb.create_sheet(title="Pi") ws2['F5'] = 3.14 ws3 = wb.create_sheet(title="Data") for row in range(10, 20): for col in range(27, 54): _ = ws3.cell(column=col, row=row, value="{0}".format(get_column_letter(col))) print(ws3['AA10'].value) wb.save(filename=dest_filename)
一共創(chuàng)建了三個(gè)Sheet
創(chuàng)建Sheet的三種方法
ws1 = wb.create_sheet("Mysheet") # 在末尾添加 # or ws2 = wb.create_sheet("Mysheet", 0) # 在開頭添加 # or ws3 = wb.create_sheet("Mysheet", -1) # 在倒數(shù)第二位添加
給Sheet中某cell賦值
ws2['F5'] = 3.14
賦值cell的值
ws3.cell(column=col, row=row, value="{0}".format(get_column_letter(col)))
讀取Excel
from openpyxl import load_workbook wb = load_workbook(filename = 'empty_book.xlsx') sheet_ranges = wb['range names'] print(sheet_ranges['D18'].value)
加載文件
wb = load_workbook(filename = 'empty_book.xlsx')
獲取sheet
sheet_ranges = wb['range names']
一個(gè)例子
我們的目標(biāo)是將相同考號(hào)的數(shù)據(jù)放入到一行中,并計(jì)算總成績(jī)
首先創(chuàng)建一個(gè)tab頁(yè)
這里需要注意直接
ws = wb['總成績(jī)']
肯定不行,因?yàn)檫@時(shí)候沒有這個(gè)tab呢 直接就會(huì)報(bào) KeyError: 'Worksheet 總成績(jī) does not exist.' 所以需要先檢查一下tab頁(yè)是否存在
if not '總成績(jī)' in wb.sheetnames: wb.create_sheet('總成績(jī)') ws = wb['總成績(jī)']
需要注意的是最后一定要進(jìn)行保存操作,否則無(wú)用 wb.save('first.xlsx')
收集數(shù)據(jù)
# 對(duì)每個(gè)tab中的分?jǐn)?shù)數(shù)據(jù)進(jìn)行收集,放入對(duì)應(yīng)的數(shù)據(jù)行中 for pos, tabName in enumerate(wb.sheetnames): if tabName != '總成績(jī)': wstt = wb[tabName] for row in wstt.iter_rows(min_row=2, values_only=True): for ind, code in enumerate(ws['A']): if code.value == row[0]: ws.cell(ind + 1, 4 + pos, row[2]) break
保存總成績(jī)
一開始直接用多字段相加
for po, row in enumerate(ws.iter_rows(min_row=2, values_only=True)): ws.cell(po + 1, 3, 0 + row[3] + row[4] + row[5] + row[6] + row[7] + row[8] + row[9])
報(bào)錯(cuò)如下
ws.cell(po + 1, 3, 0 + row[3] + row[4] + row[5] + row[6] + row[7] + row[8] + row[9]) TypeError: unsupported operand type(s) for +: 'int' and 'NoneType'
原因是其中存在NoneType,int和NoneType不能相加。 可以用int(value or 0)來(lái)將對(duì)應(yīng)的None, 0, [], ""這些Python認(rèn)為是False的轉(zhuǎn)換為1。
總結(jié)
人生苦短,我用 Python,在強(qiáng)大的Python幫助下,我們只需幾行代碼就可以生成我們想要的Excel。
以上就是python openpyxl的使用方法的詳細(xì)內(nèi)容,更多關(guān)于python openpyxl的使用的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- python 辦公自動(dòng)化——基于pyqt5和openpyxl統(tǒng)計(jì)符合要求的名單
- Python Excel處理庫(kù)openpyxl詳解
- python使用openpyxl庫(kù)讀寫Excel表格的方法(增刪改查操作)
- Python利器openpyxl之操作excel表格
- Python離線安裝openpyxl模塊的步驟
- 解決python 使用openpyxl讀寫大文件的坑
- Python openpyxl 無(wú)法保存文件的解決方案
- python openpyxl 帶格式復(fù)制表格的實(shí)現(xiàn)
- python 使用openpyxl讀取excel數(shù)據(jù)
相關(guān)文章
django2筆記之路由path語(yǔ)法的實(shí)現(xiàn)
這篇文章主要介紹了django2筆記之路由path語(yǔ)法的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07python3.6 tkinter實(shí)現(xiàn)屏保小程序
這篇文章主要為大家詳細(xì)介紹了python3.6 tkinter實(shí)現(xiàn)屏保小程序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07Python通過(guò)屬性手段實(shí)現(xiàn)只允許調(diào)用一次的示例講解
下面小編就為大家分享一篇Python通過(guò)屬性手段實(shí)現(xiàn)只允許調(diào)用一次的示例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-04-04Python爬蟲之Selenium設(shè)置元素等待的方法
這篇文章主要介紹了Python爬蟲之Selenium設(shè)置元素等待的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12Python真題案例之最長(zhǎng)回文子串 周期串詳解
今天來(lái)記錄一下字符串處理中常見到的回文子串與周期串問(wèn)題。使用的語(yǔ)言是Python優(yōu)雅的處理字符串是程序員不可或缺的技能,快來(lái)一起學(xué)習(xí)吧2022-03-03