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

Python使用xlrd模塊實(shí)現(xiàn)操作Excel讀寫的方法匯總

 更新時間:2024年10月01日 15:17:01   作者:【1758872】的博客  
本文介紹Python中使用xlrd、xlwt、xlutils模塊操作Excel文件的方法,xlrd用于讀取Excel文件,但2.0.0版本后不支持.xlsx格式,xlwt用于創(chuàng)建和寫入Excel文件,而xlutils主要用于復(fù)制和處理Excel文件,詳細(xì)介紹了如何打開文件、獲取工作表信息、操作行列數(shù)據(jù)和處理日期格式數(shù)據(jù)

1.1、xlrd模塊介紹

xlrd:用于讀取Excle數(shù)據(jù)文件將返回的數(shù)據(jù)對象放到內(nèi)存中,然后查詢數(shù)據(jù)文件對象的相關(guān)信息。

xlwt:用于在內(nèi)存中生成新的數(shù)據(jù)文件對象,處理完成后寫入到Excel數(shù)據(jù)文件中。

xlutils:主要的作用就是copy新的文件對象,在新的數(shù)據(jù)對象中完成數(shù)據(jù)處理操作。

注意:在使用 xlrd 讀取 .xlsx 文件時,由于 xlrd 從版本 2.0.0 開始停止支持 .xlsx 格式,可能會遇到 xlrd.biffh.XLRDError: Excel xlsx file; not supported 的錯誤。

如果需要讀取.xlsx文件,你可能需要安裝1.2.0版本的xlrd。

1.2、xlrd操作方法匯總

1.2.1、Excel操作

1.2.1.1、打開文件

import xlrd workbook = xlrd.open_workbook('test.xls') print(workbook) # <xlrd.book.Book object at 0x7f592100ff50>

1.2.1.2、獲取所有的表名

import xlrd workbook = xlrd.open_workbook(r'./code/excelRead/test.xls') # 獲取所有的工作表名 sheet_names = workbook.sheet_names() print(sheet_names) # ['sdxl', 'hzgg', 'sdyxz', 'TB2018'] # 獲取所有的sheet對象 Sheets = workbook.sheets() print(Sheets) # [Sheet 0:<sdxl>, Sheet 1:<hzgg>, Sheet 2:<sdyxz>, Sheet 3:<TB2018>]

1.2.1.3、獲取指定的Sheet

import xlrd workbook = xlrd.open_workbook(r'./code/excelRead/test.xls') # 方式一:通過索引選取 sheet1 = workbook.sheets()[0] print(sheet1 ) # Sheet 0:<sdxl> # 方式二:通過索引選取 sheet2 = workbook.sheet_by_index(2) print(sheet2) # Sheet 2:<sdyxz> # 方式三:通過表名選取,返回一個<class 'xlrd.sheet.Sheet'>對象 sheet = workbook.sheet_by_name("hzgg") print(sheet) # Sheet 1:<hzgg>

1.2.1.4、某個sheet是否導(dǎo)入完畢

# 通過索引,檢查某個sheet是否導(dǎo)入完畢 print(workbook.sheet_loaded(0)) # True # 通過文件名,檢查某個sheet是否導(dǎo)入完畢 print(workbook.sheet_loaded("hzgg")) # True

1.2.2、sheet對象的基本操作

1.2.2.1、sheet表行操作

1.2.2.1.1、獲取表中所有的行數(shù)

import xlrd workbook = xlrd.open_workbook(r'./code/excelRead/test.xls') sheet2 = workbook.sheet_by_name("hzgg") # 特別注意,這是屬性而不是方法,不加括號 print(sheet2.nrows) # 17

1.2.2.1.2、返回指定行的所有單元格數(shù)值組成的列表

1.2.2.1.3、獲取某行的類型及數(shù)據(jù)

1.2.2.1.4、獲取某行的類型的列表

單元類型ctype:empty為0,string為1,number為2,date為3,boolean為4, error為5(左邊為類型,右邊為類型對應(yīng)的值) 

1.2.2.1.5、以切片形式獲取某行的類型及數(shù)據(jù)
1.2.2.1.6、獲取某行的長度
1.2.2.1.7、獲取sheet的所有行生成器


1.2.2.2、sheet表列操作

1.2.2.2.1、獲取有效列數(shù)

import xlrd workbook = xlrd.open_workbook(r'./code/excelRead/test.xls') sheet2 = workbook.sheet_by_name("hzgg") # 獲取有效列數(shù) print(sheet2.ncols) # 9

1.2.2.2.2、獲取某列數(shù)據(jù)
1.2.2.2.3、獲取某列類型
1.2.2.2.4、以切片方式獲取某列類型及數(shù)據(jù) 

1.2.2.3、單元格操作


1.2.2.4、單元格中的日期/時間操作

在使用xlrd讀取excel時,我們常常會遇到日期格式的數(shù)據(jù),如果我們不經(jīng)過任何處理,那么我們得到會是如 45089.0、45171.0 這樣的excel時間戳。那么我們該如何讀取呢?這里介紹倆方法。

1.2.2.4.1、xlrd.xldate_as_tuple(xldate, datemode)

xlrd.xldate_as_tuple(xldate,datemode)

    :param xldate: 要處理的單元格值,自然是excel中的日期數(shù)據(jù)

    :param datemode: 使用哪條基準(zhǔn)的時間戳(0代表1900-01-01為基準(zhǔn),1代表1904-01-01為基準(zhǔn));常使用1900為基準(zhǔn)

返回值:返回一個元組,類似于(year,month,day,hour,minute,nearest_second)

但是,僅適用于date類型的excel單元格,不適用于time類型的單元格,對于time類型的單元格值,報錯:XLDateAmbiguous

1.2.2.4.2、xlrd.xldate.xldate_as_datetime(xldate, datemode)

xlrd.xldate.xldate_as_datetime(xldate,datemode)

    :param xldate: 要處理的單元格值,自然是excel中的日期數(shù)據(jù)

    :param datemode: 使用哪條基準(zhǔn)的時間戳(0代表1900-01-01為基準(zhǔn),1代表1904-01-01為基準(zhǔn));常使用1900為基準(zhǔn)

返回值:datetime對象,格式 year-month-day hour:minute:second

但是,對于time類型的單元格值,轉(zhuǎn)化后自動以基準(zhǔn)補(bǔ)充;如基準(zhǔn)選擇1900時,時間 13:09:30 轉(zhuǎn)化后為:1900-01-01 23:08:00

到此這篇關(guān)于Python使用xlrd模塊實(shí)現(xiàn)Excel讀寫的方法匯總的文章就介紹到這了,更多相關(guān)xlrd模塊實(shí)現(xiàn)Excel讀寫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python?os和os.path模塊詳情

    Python?os和os.path模塊詳情

    這篇文章主要介紹了Python?os和os.path模塊詳情,文章圍繞主題展開詳細(xì)的相關(guān)內(nèi)容,具有一定的參考價值,需要的小伙伴可以參考一下,希望對你的學(xué)習(xí)有所幫助
    2022-04-04
  • Flask藍(lán)圖學(xué)習(xí)教程

    Flask藍(lán)圖學(xué)習(xí)教程

    在Flask中,使用藍(lán)圖Blueprint來分模塊組織管理。藍(lán)圖實(shí)際可以理解為是一個存儲一組視圖方法的容器對象,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-10-10
  • 如何在python開發(fā)工具PyCharm中搭建QtPy環(huán)境(教程詳解)

    如何在python開發(fā)工具PyCharm中搭建QtPy環(huán)境(教程詳解)

    這篇文章主要介紹了在python開發(fā)工具PyCharm中搭建QtPy環(huán)境,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • 在arcgis使用python腳本進(jìn)行字段計算時是如何解決中文問題的

    在arcgis使用python腳本進(jìn)行字段計算時是如何解決中文問題的

    這篇文章主要介紹了在arcgis使用python腳本進(jìn)行字段計算時是如何解決中文問題的,需要的朋友可以參考下
    2015-10-10
  • Django日志模塊logging的配置詳解

    Django日志模塊logging的配置詳解

    日志在程序開發(fā)中是少不了的,通過日志我們可以分析到錯誤在什么地方,有什么異常。在生產(chǎn)環(huán)境下有很大的用處。在java 開發(fā)中通常用 log4j,logback 等三方組件。下面這篇文章主要介紹了Django日志模塊logging的相關(guān)資料,需要的朋友可以參考下。
    2017-02-02
  • python學(xué)生管理系統(tǒng)

    python學(xué)生管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了python學(xué)生管理系統(tǒng)的相關(guān)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Django?報錯:Broken?pipe?from?('127.0.0.1',?58924)的解決

    Django?報錯:Broken?pipe?from?('127.0.0.1',?5892

    這篇文章主要介紹了Django?報錯:Broken?pipe?from?('127.0.0.1',?58924)的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • python接口測試對修改密碼接口進(jìn)行壓測

    python接口測試對修改密碼接口進(jìn)行壓測

    這篇文章主要為大家介紹了python接口測試對修改密碼接口進(jìn)行壓測的腳本實(shí)現(xiàn),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • python使用jieba實(shí)現(xiàn)中文分詞去停用詞方法示例

    python使用jieba實(shí)現(xiàn)中文分詞去停用詞方法示例

    jieba分詞,完全開源,有集成的python庫,簡單易用。下面這篇文章主要給大家介紹了關(guān)于python使用jieba實(shí)現(xiàn)中文分詞去停用詞的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。
    2018-03-03
  • python pytorch中.view()函數(shù)的用法解讀

    python pytorch中.view()函數(shù)的用法解讀

    這篇文章主要介紹了python pytorch中.view()函數(shù)的用法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08

最新評論