Python如何使用xlrd和xlwt庫讀寫excel文件
如何讀寫excel文件?
實際案例
Microsoft Excel是日常辦公中使用最頻繁的軟件,其數(shù)據(jù)格式為xls,xlsx,一種非常常用的電子表格。
小學某班成績,記錄在excel文件中:
姓名 語文 數(shù)學 外語 李雷 95 99 96 韓梅 98 100 93 張峰 94 95 95 .... ....
利用python讀寫excel,添加"總分"列,計算每人總分。
解決方案
使用pip3安裝:$ pip3 install xlrd xlwt
使用第三方庫xlrd和xlwt,這兩個庫分別用于excel讀reader(rd)和寫writer(wt) 。
注意:
[1] xlrd 2.1.0最新版本是不支持xlsx文件,可以創(chuàng)建xls文件復制之前內(nèi)容粘貼,或者卸載現(xiàn)在版本然后重新安裝xlrd==1.1.0。
[2] excel文件格式類型為"Microsoft Excel 97-2003 文件(*.xls)"
代碼演示
(1)excel文件的讀xlrd和xlwt寫使用
import xlrd # 讀取excel,返回一個對象 book = xlrd.open_workbook('demo.xls') # 獲取一個book當中所有的表,返回一個列表其中每一個項是sheet對象 print(book.sheets()[0]) # 還可以通過sheet_by_name或sheet_by_name得到表 sheet = book.sheet_by_index(0) print(sheet) # 獲取一張表行數(shù)和列數(shù) r_num = sheet.nrows c_num = sheet.ncols print(r_num, c_num) ''' 一個book可以包含許多的表(sheet),一張表是由一個個單元格構(gòu)成, 一個單元格也就是一個cell。 ''' # 如果獲取每一個cell(單元格)的對象,需要傳入行列坐標 print(sheet.cell(0, 0)) print(sheet.cell(1, 1)) # 單元格中內(nèi)容的類型,它是一個枚舉值,可以通過xlrd.XL_CELL_[類型]查看枚舉值對應類型 print(sheet.cell(0, 0).ctype) print(sheet.cell(1, 1).ctype) # 獲取cell對象的值 print(sheet.cell(0, 0).value) print(sheet.cell(1, 1).value) # 一次性獲取一行數(shù)據(jù)或一列數(shù)據(jù),傳入行號或列號 r1 = sheet.row(1) # 返回一個列表,其中每一個都是cell對象 print(r1) # 不想獲取cell對象,只想獲取其中值 print(sheet.row_values(1)) # 還可以類似于切片操作指定某一個列的范圍 # 第1個參數(shù)為行號,第2個參數(shù)為起始列 print(sheet.row_values(1, 1)) # 為表添加單元格,參數(shù):行值、列值、類型、內(nèi)容、字體的對齊方式 # sheet.put_cell() # 寫excel import xlwt # 創(chuàng)建excel,實例化一個workbook w_book = xlwt.Workbook() # 添加表 w_sheet = w_book.add_sheet('sheet1') # 為表添加單元格 w_sheet.write(0, 0) # 寫入到文件中,輸出文件的文件名 w_book.save('output.xls')
(2)實現(xiàn)excel文本的處理和保存
import xlrd, xlwt # 打開excel r_book = xlrd.open_workbook('demo.xls') # 得到第一張表 r_sheet = r_book.sheet_by_index(0) # 獲得表的列數(shù) nc = r_sheet.ncols # 向表中添加cell單元格,傳入:行號,列號,類型 r_sheet.put_cell(0, nc, xlrd.XL_CELL_TEXT, '總分', None) # 迭代每一行計算總分 for row in range(1, r_sheet.nrows): # 跳過第1列,得到之后每個單元格內(nèi)容列表求和 t = sum(r_sheet.row_values(row, 1)) # 添加一個cell單元格,存放每個學生的總分 r_sheet.put_cell(row, nc, xlrd.XL_CELL_NUMBER, t, None) # 寫入到excel文件中 w_book = xlwt.Workbook() w_sheet = w_book.add_sheet(r_sheet.name) # 設(shè)置對齊方式,水平和垂直都居中 style = xlwt.easyxf('align: vertical center, horizontal center') # 將r_sheet單元格內(nèi)容寫到w_sheet當中 for r in range(r_sheet.nrows): for c in range(r_sheet.ncols): w_sheet.write(r, c, r_sheet.cell_value(r, c), style) # 保存內(nèi)容 w_book.save('output.xls')
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python基礎(chǔ)教程之正則表達式基本語法以及re模塊
正則表達式是可以匹配文本片段的模式,今天的Python就跟大家一起討論一下python中的re模塊,python re模塊感興趣的朋友一起學習吧2016-03-03Python實現(xiàn)批量將MP3音頻轉(zhuǎn)為WAV格式詳解
這篇文章主要介紹了通過Python實現(xiàn)將MP3音頻轉(zhuǎn)為WAV格式的方法,文中的示例代碼講解詳細,對我們學習Python有一定幫助,感興趣的可以了解一下2021-12-12Flask框架踩坑之a(chǎn)jax跨域請求實現(xiàn)
這篇文章主要介紹了Flask框架踩坑之a(chǎn)jax跨域請求實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02深入了解Python中Pytest Markers的使用方法
從這篇開始,逐一解決fixture是啥,mark是啥,參數(shù)request是啥,鉤子函數(shù)是啥,parametrize參數(shù)化是啥,這些問題,本片先介紹一下mark是啥,以及如何使用2023-09-09