中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python如何使用xlrd模塊讀取excel

發布時間:2022-03-07 11:56:31 來源:億速云 閱讀:229 作者:小新 欄目:開發技術

這篇文章主要介紹了python如何使用xlrd模塊讀取excel,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

    一、安裝xlrd模塊:

    1、mac下打開終端輸入命令:

    pip install xlrd

    2、驗證安裝是否成功:

    • 在mac終端輸入 python  進入python環境

    • 然后輸入 import xlrd

    不報錯說明模塊安裝成功

    二、常用方法:

    1、導入模塊:

    import xlrd

    2、打開文件:

    x1 = xlrd.open_workbook("data.xlsx")

    3、獲取sheet:

    • 獲取所有sheet名字:x1.sheet_names()

    • 獲取sheet數量:x1.nsheets

    • 獲取所有sheet對象:x1.sheets()

    • 通過sheet名查找:x1.sheet_by_name("test”)

    • 通過索引查找:x1.sheet_by_index(3)

    # -*- coding:utf-8 -*-
    
    import xlrd
    import os
    
    filename = "demo.xlsx"
    filePath = os.path.join(os.getcwd(), filename)
    
    print filePath
    
    # 1、打開文件
    x1 = xlrd.open_workbook(filePath)
    
    # 2、獲取sheet對象
    print 'sheet_names:', x1.sheet_names()  # 獲取所有sheet名字
    print 'sheet_number:', x1.nsheets        # 獲取sheet數量
    print 'sheet_object:', x1.sheets()       # 獲取所有sheet對象
    print 'By_name:', x1.sheet_by_name("test")  # 通過sheet名查找
    print 'By_index:', x1.sheet_by_index(3)  # 通過索引查找

    輸出:

    sheet_names: [u' plan', u'team building', u'modile', u'test']
    sheet_number: 4
    sheet_object: [<xlrd.sheet.Sheet object at 0x10244c190>, <xlrd.sheet.Sheet object at 0x10244c150>, <xlrd.sheet.Sheet object at 0x10244c110>, <xlrd.sheet.Sheet object at 0x10244c290>]
    By_name: <xlrd.sheet.Sheet object at 0x10244c290>
    By_index: <xlrd.sheet.Sheet object at 0x10244c290>

    4、獲取sheet的匯總數據:

    • 獲取sheet名:sheet1.name

    • 獲取總行數:sheet1.nrows

    • 獲取總列數:sheet1.ncols

    # -*- coding:utf-8 -*-
    import xlrd
    import os
    from datetime import date,datetime
    
    filename = "demo.xlsx"
    filePath = os.path.join(os.getcwd(), filename)
    print filePath
    
    # 打開文件
    x1 = xlrd.open_workbook(filePath)
    
    # 獲取sheet的匯總數據
    sheet1 = x1.sheet_by_name("plan")
    print "sheet name:", sheet1.name   # get sheet name
    print "row num:", sheet1.nrows  # get sheet all rows number
    print "col num:", sheet1.ncols  # get sheet all columns number

    輸出:

    sheet name: plan
    row num: 31
    col num: 11

    5、單元格批量讀取:

     a)行操作:

    • sheet1.row_values(0)  # 獲取第一行所有內容,合并單元格,首行顯示值,其它為空。

    • sheet1.row(0)           # 獲取單元格值類型和內容

    • sheet1.row_types(0)   # 獲取單元格數據類型

    # -*- coding:utf-8 -*-
    
    import xlrd
    import os
    from datetime import date,datetime
    
    filename = "demo.xlsx"
    filePath = os.path.join(os.getcwd(), filename)
    
    x1 = xlrd.open_workbook(filePath)
    sheet1 = x1.sheet_by_name("plan")
    
    # 單元格批量讀取
    print sheet1.row_values(0)  # 獲取第一行所有內容,合并單元格,首行顯示值,其它為空。
    print sheet1.row(0)         # 獲取單元格值類型和內容
    print sheet1.row_types(0)   # 獲取單元格數據類型

    輸出:

    [u'learning plan', u'', u'', u'', u'', u'', u'', u'', 123.0, 42916.0, 0]
    [text:u'learning plan', empty:u'', empty:u'', empty:u'', empty:u'', empty:u'', empty:u'', empty:u'', number:123.0, xldate:42916.0, bool:0]
    array('B', [1, 0, 0, 0, 0, 0, 0, 0, 2, 3, 4])

    b) 表操作

    • sheet1.row_values(0, 6, 10)   # 取第1行,第6~10列(不含第10表)

    • sheet1.col_values(0, 0, 5)    # 取第1列,第0~5行(不含第5行)

    • sheet1.row_slice(2, 0, 2)     # 獲取單元格值類型和內容

    • sheet1.row_types(1, 0, 2)   # 獲取單元格數據類型

    # -*- coding:utf-8 -*-
    
    import xlrd
    import os
    from datetime import date,datetime
    
    filename = "demo.xlsx"
    filePath = os.path.join(os.getcwd(), filename)
    
    print filePath
    
    # 1、打開文件
    x1 = xlrd.open_workbook(filePath)
    sheet1 = x1.sheet_by_name("plan")
    
    # 列操作
    print sheet1.row_values(0, 6, 10)   # 取第1行,第6~10列(不含第10表)
    print sheet1.col_values(0, 0, 5)    # 取第1列,第0~5行(不含第5行)
    print sheet1.row_slice(2, 0, 2)     # 獲取單元格值類型和內容,同sheet1.row(0)
    print sheet1.row_types(1, 0, 2)     # 獲取單元格數據類型

    輸出:

    [u'', u'', 123.0, 42916.0]
    [u'learning plan', u'\u7f16\u53f7', 1.0, 2.0, 3.0]
    [number:1.0, text:u'\u7ba1\u7406\u5b66\u4e60']
    array('B', [1, 1])

    6、特定單元格讀取:

     a) 獲取單元格值:

    • sheet1.cell_value(1, 2)

    • sheet1.cell(1, 2).value

    • sheet1.row(1)[2].value 

    b) 獲取單元格類型:

    • sheet1.cell(1, 2).ctype

    • sheet1.cell_type(1, 2)

    • sheet1.row(1)[2].ctype

    # -*- coding:utf-8 -*-
    
    import xlrd
    import os
    from datetime import date,datetime
    
    filename = "demo.xlsx"
    filePath = os.path.join(os.getcwd(), filename)
    
    x1 = xlrd.open_workbook(filePath)
    sheet1 = x1.sheet_by_name("plan")
    
    # 特定單元格讀取
    # 取值
    print sheet1.cell_value(1, 2)
    print sheet1.cell(1, 2).value
    print sheet1.row(1)[2].value
    
    #取類型
    print sheet1.cell(1, 2).ctype
    print sheet1.cell_type(1, 2)
    print sheet1.row(1)[2].ctype

    7、(0,0)轉換A1:

    • xlrd.cellname(0, 0)   # (0,0)轉換成A1

    • xlrd.cellnameabs(0, 0) # (0,0)轉換成$A$1

    • xlrd.colname(30)  # 把列由數字轉換為字母表示

    # -*- coding:utf-8 -*-
    
    import xlrd
    import os
    
    filename = "demo.xlsx"
    filePath = os.path.join(os.getcwd(), filename)
    
    # 打開文件
    x1 = xlrd.open_workbook(filePath)
    sheet1 = x1.sheet_by_name("plan")
    
    # (0,0)轉換成A1
    print xlrd.cellname(0, 0)   # (0,0)轉換成A1
    print xlrd.cellnameabs(0, 0) # (0,0)轉換成$A$1
    print xlrd.colname(30)  # 把列由數字轉換為字母表示

    輸出:

    A1
    $A$1
    AE

    8、數據類型:

    • 空:0

    • 字符串:1

    • 數字:2

    • 日期:3

    • 布爾:4

    • error:5

    附:寫一個自動獲取excel表內容的類

    本代碼已實現自動轉換單元格數據類型,不會發生整形數字以浮點數顯示,布爾型True或False顯示為1,0;日期時間顯示為一連串的小數問題

    import xlrd
    from xlrd import xldate_as_tuple
    import datetime
    '''
    xlrd中單元格的數據類型
    數字一律按浮點型輸出,日期輸出成一串小數,布爾型輸出0或1,所以我們必須在程序中做判斷處理轉換
    成我們想要的數據類型
    0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error
    '''
    class ExcelData():
        # 初始化方法
        def __init__(self, data_path, sheetname):
            #定義一個屬性接收文件路徑
            self.data_path = data_path
            # 定義一個屬性接收工作表名稱
            self.sheetname = sheetname
            # 使用xlrd模塊打開excel表讀取數據
            self.data = xlrd.open_workbook(self.data_path)
            # 根據工作表的名稱獲取工作表中的內容(方式①)
            self.table = self.data.sheet_by_name(self.sheetname)
            # 根據工作表的索引獲取工作表的內容(方式②)
            # self.table = self.data.sheet_by_name(0)
            # 獲取第一行所有內容,如果括號中1就是第二行,這點跟列表索引類似
            self.keys = self.table.row_values(0)
            # 獲取工作表的有效行數
            self.rowNum = self.table.nrows
            # 獲取工作表的有效列數
            self.colNum = self.table.ncols
    
        # 定義一個讀取excel表的方法
        def readExcel(self):
            # 定義一個空列表
            datas = []
            for i in range(1, self.rowNum):
                # 定義一個空字典
                sheet_data = {}
                for j in range(self.colNum):
                    # 獲取單元格數據類型
                    c_type = self.table.cell(i,j).ctype
                    # 獲取單元格數據
                    c_cell = self.table.cell_value(i, j)
                    if c_type == 2 and c_cell % 1 == 0:  # 如果是整形
                        c_cell = int(c_cell)
                    elif c_type == 3:
                        # 轉成datetime對象
                        date = datetime.datetime(*xldate_as_tuple(c_cell,0))
                        c_cell = date.strftime('%Y/%d/%m %H:%M:%S')
                    elif c_type == 4:
                        c_cell = True if c_cell == 1 else False
                    sheet_data[self.keys[j]] = c_cell
                    # 循環每一個有效的單元格,將字段與值對應存儲到字典中
                    # 字典的key就是excel表中每列第一行的字段
                    # sheet_data[self.keys[j]] = self.table.row_values(i)[j]
                # 再將字典追加到列表中
                datas.append(sheet_data)
            # 返回從excel中獲取到的數據:以列表存字典的形式返回
            return datas
    if __name__ == "__main__":
        data_path = "ttt.xlsx"
        sheetname = "Sheet1"
        get_data = ExcelData(data_path, sheetname)
        datas = get_data.readExcel()
        print(datas)

    感謝你能夠認真閱讀完這篇文章,希望小編分享的“python如何使用xlrd模塊讀取excel”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    乐山市| 湖南省| 梨树县| 昌都县| 清徐县| 河北省| 阿勒泰市| 汉寿县| 香格里拉县| 旬阳县| 淳化县| 莱州市| 新晃| 南昌县| 平原县| 灵寿县| 汨罗市| 台中市| 太和县| 来宾市| 罗平县| 桃园县| 鲜城| 巴马| 昌黎县| 二手房| 松阳县| 苍南县| 浮山县| 新绛县| 东城区| 新闻| 那曲县| 开远市| 富源县| 英山县| 金坛市| 西盟| 峡江县| 酉阳| 沽源县|