程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
您现在的位置: 程式師世界 >> 編程語言 >  >> 更多編程語言 >> Python

Python使用xlrd和xlwt庫讀寫excel文件詳解

編輯:Python

1、如何讀寫excel文件?

        實際案例:

                Microsoft Excel是日常辦公中使用最頻繁的軟件,其數據格式為xls,xlsx,一種非常常用的電子表格。小學某班成績,記錄在excel文件中:

 姓名 語文 數學 外語
李雷 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文件,可以創建xls文件復制之前內容粘貼,或者卸載現在版本然後重新安裝xlrd==1.1.0。

                  [2] excel文件格式類型為"Microsoft Excel 97-2003 文件(*.xls)"

2、代碼演示

(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)
# 獲取一張表行數和列數
r_num = sheet.nrows
c_num = sheet.ncols
print(r_num, c_num)
'''
一個book可以包含許多的表(sheet),一張表是由一個個單元格構成,
一個單元格也就是一個cell。
'''
# 如果獲取每一個cell(單元格)的對象,需要傳入行列坐標
print(sheet.cell(0, 0))
print(sheet.cell(1, 1))
# 單元格中內容的類型,它是一個枚舉值,可以通過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)
# 一次性獲取一行數據或一列數據,傳入行號或列號
r1 = sheet.row(1)
# 返回一個列表,其中每一個都是cell對象
print(r1)
# 不想獲取cell對象,只想獲取其中值
print(sheet.row_values(1))
# 還可以類似於切片操作指定某一個列的范圍
# 第1個參數為行號,第2個參數為起始列
print(sheet.row_values(1, 1))
# 為表添加單元格,參數:行值、列值、類型、內容、字體的對齊方式
# sheet.put_cell()
# 寫excel
import xlwt
# 創建excel,實例化一個workbook
w_book = xlwt.Workbook()
# 添加表
w_sheet = w_book.add_sheet('sheet1')
# 為表添加單元格
w_sheet.write(0, 0)
# 寫入到文件中,輸出文件的文件名
w_book.save('output.xls')

(2)實現excel文本的處理和保存

import xlrd, xlwt
# 打開excel
r_book = xlrd.open_workbook('demo.xls')
# 得到第一張表
r_sheet = r_book.sheet_by_index(0)
# 獲得表的列數
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列,得到之後每個單元格內容列表求和
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)
# 設置對齊方式,水平和垂直都居中
style = xlwt.easyxf('align: vertical center, horizontal center')
# 將r_sheet單元格內容寫到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)
# 保存內容
w_book.save('output.xls')


  1. 上一篇文章:
  2. 下一篇文章:
Copyright © 程式師世界 All Rights Reserved