欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python如何使用xlrd和xlwt庫(kù)讀寫(xiě)excel文件

 更新時(shí)間:2024年02月10日 09:44:03   作者:AllardZhao  
這篇文章主要介紹了Python如何使用xlrd和xlwt庫(kù)讀寫(xiě)excel文件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

如何讀寫(xiě)excel文件?

實(shí)際案例

Microsoft Excel是日常辦公中使用最頻繁的軟件,其數(shù)據(jù)格式為xls,xlsx,一種非常常用的電子表格。

小學(xué)某班成績(jī),記錄在excel文件中:

    姓名    語(yǔ)文    數(shù)學(xué)    外語(yǔ)
    李雷    95      99     96	
    韓梅    98      100    93
    張峰    94      95     95
    .... ....

利用python讀寫(xiě)excel,添加"總分"列,計(jì)算每人總分。

解決方案

使用pip3安裝:$ pip3 install xlrd xlwt

使用第三方庫(kù)xlrd和xlwt,這兩個(gè)庫(kù)分別用于excel讀reader(rd)和寫(xiě)writer(wt) 。

注意:

[1] xlrd 2.1.0最新版本是不支持xlsx文件,可以創(chuàng)建xls文件復(fù)制之前內(nèi)容粘貼,或者卸載現(xiàn)在版本然后重新安裝xlrd==1.1.0。

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

代碼演示

(1)excel文件的讀xlrd和xlwt寫(xiě)使用

import xlrd
 
# 讀取excel,返回一個(gè)對(duì)象
book = xlrd.open_workbook('demo.xls')
# 獲取一個(gè)book當(dāng)中所有的表,返回一個(gè)列表其中每一個(gè)項(xiàng)是sheet對(duì)象
print(book.sheets()[0])
# 還可以通過(guò)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)
'''
一個(gè)book可以包含許多的表(sheet),一張表是由一個(gè)個(gè)單元格構(gòu)成,
一個(gè)單元格也就是一個(gè)cell。
'''
# 如果獲取每一個(gè)cell(單元格)的對(duì)象,需要傳入行列坐標(biāo)
print(sheet.cell(0, 0))
print(sheet.cell(1, 1))
# 單元格中內(nèi)容的類(lèi)型,它是一個(gè)枚舉值,可以通過(guò)xlrd.XL_CELL_[類(lèi)型]查看枚舉值對(duì)應(yīng)類(lèi)型
print(sheet.cell(0, 0).ctype)
print(sheet.cell(1, 1).ctype)
# 獲取cell對(duì)象的值
print(sheet.cell(0, 0).value)
print(sheet.cell(1, 1).value)
 
# 一次性獲取一行數(shù)據(jù)或一列數(shù)據(jù),傳入行號(hào)或列號(hào)
r1 = sheet.row(1)
# 返回一個(gè)列表,其中每一個(gè)都是cell對(duì)象
print(r1)
# 不想獲取cell對(duì)象,只想獲取其中值
print(sheet.row_values(1))
# 還可以類(lèi)似于切片操作指定某一個(gè)列的范圍
# 第1個(gè)參數(shù)為行號(hào),第2個(gè)參數(shù)為起始列
print(sheet.row_values(1, 1))
 
# 為表添加單元格,參數(shù):行值、列值、類(lèi)型、內(nèi)容、字體的對(duì)齊方式
# sheet.put_cell()
 
# 寫(xiě)excel
import xlwt
 
# 創(chuàng)建excel,實(shí)例化一個(gè)workbook
w_book = xlwt.Workbook()
# 添加表
w_sheet = w_book.add_sheet('sheet1')
# 為表添加單元格
w_sheet.write(0, 0)
 
# 寫(xiě)入到文件中,輸出文件的文件名
w_book.save('output.xls')

(2)實(shí)現(xiàn)excel文本的處理和保存

import xlrd, xlwt
 
# 打開(kāi)excel
r_book = xlrd.open_workbook('demo.xls')
# 得到第一張表
r_sheet = r_book.sheet_by_index(0)
# 獲得表的列數(shù)
nc = r_sheet.ncols
# 向表中添加cell單元格,傳入:行號(hào),列號(hào),類(lèi)型
r_sheet.put_cell(0, nc, xlrd.XL_CELL_TEXT, '總分', None)
# 迭代每一行計(jì)算總分
for row in range(1, r_sheet.nrows):
    # 跳過(guò)第1列,得到之后每個(gè)單元格內(nèi)容列表求和
    t = sum(r_sheet.row_values(row, 1))
    # 添加一個(gè)cell單元格,存放每個(gè)學(xué)生的總分
    r_sheet.put_cell(row, nc, xlrd.XL_CELL_NUMBER, t, None)
 
# 寫(xiě)入到excel文件中
w_book = xlwt.Workbook()
w_sheet = w_book.add_sheet(r_sheet.name)
# 設(shè)置對(duì)齊方式,水平和垂直都居中
style = xlwt.easyxf('align: vertical center, horizontal center')
# 將r_sheet單元格內(nèi)容寫(xiě)到w_sheet當(dāng)中
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é)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python輸出列表(list)的倒序/逆序的幾種方法

    Python輸出列表(list)的倒序/逆序的幾種方法

    列表是一個(gè)有序的元素集合,而列表的倒序或逆序操作也是常見(jiàn)的需求之一,本文主要介紹了Python輸出列表(list)的倒序/逆序的幾種方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-02-02
  • Python中偏函數(shù)用法示例

    Python中偏函數(shù)用法示例

    這篇文章主要介紹了Python中偏函數(shù)用法,結(jié)合實(shí)例形式分析了Python基于functools模塊創(chuàng)建和使用偏函數(shù)的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2018-06-06
  • python設(shè)置代理和添加鏡像源的方法

    python設(shè)置代理和添加鏡像源的方法

    這篇文章主要介紹了python設(shè)置代理和添加鏡像源介紹,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-02-02
  • Python基礎(chǔ)教程之正則表達(dá)式基本語(yǔ)法以及re模塊

    Python基礎(chǔ)教程之正則表達(dá)式基本語(yǔ)法以及re模塊

    正則表達(dá)式是可以匹配文本片段的模式,今天的Python就跟大家一起討論一下python中的re模塊,python re模塊感興趣的朋友一起學(xué)習(xí)吧
    2016-03-03
  • 10個(gè)Python自動(dòng)化辦公的腳本分享

    10個(gè)Python自動(dòng)化辦公的腳本分享

    在日常辦公中,我們常常會(huì)被繁瑣、重復(fù)的任務(wù)占據(jù)大量時(shí)間,本文為大家分享了10個(gè)實(shí)用的?Python?自動(dòng)化辦公案例及源碼,希望對(duì)大家有所幫助
    2025-02-02
  • Django多對(duì)多ManyToManyField字段的使用

    Django多對(duì)多ManyToManyField字段的使用

    Django是一個(gè)支持多對(duì)多關(guān)系的Web框架,可以在模型中定義多對(duì)多關(guān)系,本文主要介紹了Django多對(duì)多ManyToManyField字段的使用,感興趣的可以了解一下
    2023-12-12
  • Python實(shí)現(xiàn)批量將MP3音頻轉(zhuǎn)為WAV格式詳解

    Python實(shí)現(xiàn)批量將MP3音頻轉(zhuǎn)為WAV格式詳解

    這篇文章主要介紹了通過(guò)Python實(shí)現(xiàn)將MP3音頻轉(zhuǎn)為WAV格式的方法,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python有一定幫助,感興趣的可以了解一下
    2021-12-12
  • Flask框架踩坑之a(chǎn)jax跨域請(qǐng)求實(shí)現(xiàn)

    Flask框架踩坑之a(chǎn)jax跨域請(qǐng)求實(shí)現(xiàn)

    這篇文章主要介紹了Flask框架踩坑之a(chǎn)jax跨域請(qǐng)求實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-02-02
  • 用Python一鍵搭建Http服務(wù)器的方法

    用Python一鍵搭建Http服務(wù)器的方法

    今天小編就為大家分享一篇用Python一鍵搭建Http服務(wù)器的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • 深入了解Python中Pytest Markers的使用方法

    深入了解Python中Pytest Markers的使用方法

    從這篇開(kāi)始,逐一解決fixture是啥,mark是啥,參數(shù)request是啥,鉤子函數(shù)是啥,parametrize參數(shù)化是啥,這些問(wèn)題,本片先介紹一下mark是啥,以及如何使用
    2023-09-09

最新評(píng)論