創(chuàng)新互聯(lián)www.cdcxhl.cn八線動態(tài)BGP香港云服務(wù)器提供商,新人活動買多久送多久,劃算不套路!
創(chuàng)新互聯(lián)云計(jì)算的互聯(lián)網(wǎng)服務(wù)提供商,擁有超過13年的服務(wù)器租用、四川服務(wù)器托管、云服務(wù)器、虛擬空間、網(wǎng)站系統(tǒng)開發(fā)經(jīng)驗(yàn),已先后獲得國家工業(yè)和信息化部頒發(fā)的互聯(lián)網(wǎng)數(shù)據(jù)中心業(yè)務(wù)許可證。專業(yè)提供云主機(jī)、虛擬空間、域名申請、VPS主機(jī)、云服務(wù)器、香港云服務(wù)器、免備案服務(wù)器等。小編給大家分享一下python中處理excel的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
Excel是我們?nèi)粘9ぷ髦薪?jīng)常用到的辦公軟件,在處理數(shù)據(jù)和表格方面有著優(yōu)異的性能,那么能不能用python來操作Excel呢?答案是肯定的,openpyxl是一個第三方庫,可以處理xlsx格式的Excel文件。
pip install openpyxl安裝。
讀取Excel文件
需要導(dǎo)入相關(guān)函數(shù)
from openpyxl import load_workbook # 默認(rèn)可讀寫,若有需要可以指定write_only和read_only為True wb = load_workbook('pythontab.xlsx') 默認(rèn)打開的文件為可讀寫,若有需要可以指定參數(shù)read_only為True。
獲取工作表--Sheet
# 獲得所有sheet的名稱 print(wb.get_sheet_names()) # 根據(jù)sheet名字獲得sheet a_sheet = wb.get_sheet_by_name('Sheet1') # 獲得sheet名 print(a_sheet.title) # 獲得當(dāng)前正在顯示的sheet, 也可以用wb.get_active_sheet() sheet = wb.active
獲取單元格
# 獲取某個單元格的值,觀察excel發(fā)現(xiàn)也是先字母再數(shù)字的順序,即先列再行 b4 = sheet['B4'] # 分別返回 print(f'({b4.column}, {b4.row}) is {b4.value}') # 返回的數(shù)字就是int型 # 除了用下標(biāo)的方式獲得,還可以用cell函數(shù), 換成數(shù)字,這個表示B2 b4_too = sheet.cell(row=4, column=2) print(b4_too.value)
b4.column返回B, b4.row返回4, value則是那個單元格的值。另外cell還有一個屬性coordinate, 像b4這個單元格返回的是坐標(biāo)B4。
獲得大行和大列
獲取行和列
sheet.rows為生成器, 里面是每一行的數(shù)據(jù),每一行又由一個tuple包裹。
sheet.columns類似,不過里面是每個tuple是每一列的單元格。
# 因?yàn)榘葱?,所以返回A1, B1, C1這樣的順序 for row in sheet.rows: for cell in row: print(cell.value) # A1, A2, A3這樣的順序 for column in sheet.columns: for cell in column: print(cell.value)
上面的代碼就可以獲得所有單元格的數(shù)據(jù)。如果要獲得某行的數(shù)據(jù)呢?給其一個索引就行了,因?yàn)閟heet.rows是生成器類型,不能使用索引,轉(zhuǎn)換成list之后再使用索引,list(sheet.rows)[2]這樣就獲取到第二行的tuple對象。
for cell in list(sheet.rows)[2]: print(cell.value)
以上是python中處理excel的方法的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道!