溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Python操作Excel方法中openpyxl怎么用

發(fā)布時(shí)間:2022-01-13 10:47:14 來(lái)源:億速云 閱讀:144 作者:iii 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹了Python操作Excel方法中openpyxl怎么用的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Python操作Excel方法中openpyxl怎么用文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。

    Python操作Excel之openpyxl

    openpyxl是一個(gè)Python庫(kù),用來(lái)讀寫(xiě)Excel2010 xlsx/xlsm/xltx/xltm類(lèi)型文件。

    openpyxl不能操作早期的xls格式的Excel文件,可以使用xlwings等其他庫(kù)。

    openpyxl是一個(gè)非標(biāo)準(zhǔn)的庫(kù),需要自行安裝:pip install openpyxl

    前提

    既然要操作Excel,那么前提我們對(duì)Excel要有一個(gè)基本的了解,比如:

    一個(gè)Excel工作簿(workbook)由一個(gè)或多個(gè)工作表(sheet組成),一個(gè)工作表(sheet)中又包含多個(gè)行(row)和列(column),每一行(row)或每一列(column)又是由多個(gè)單元格(cell)組成

    創(chuàng)建

    from openpyxl import Workbook
    # 創(chuàng)建一個(gè)工作簿對(duì)象
    wb = Workbook()
    # 創(chuàng)建一個(gè)名為first的sheet頁(yè) [第二個(gè)參數(shù)可以指定索引,即創(chuàng)建sheet的位置]
    ws = wb.create_sheet('first')
    # 將創(chuàng)建的工作簿保存為Mytest.xlsx
    wb.save('Eric_01.xlsx')
    # 最后關(guān)閉文件
    wb.close()

    Workbook對(duì)象提供了很多屬性和方法,其中,大部分方法都與sheet有關(guān)

    部分屬性如下:

    • active:獲取當(dāng)前活躍的Worksheet

    • worksheets:以列表的形式返回所有的Worksheet(表格)

    • read_only:判斷是否以read_only模式打開(kāi)Excel文檔

    • encoding:獲取文檔的字符集編碼

    • properties:獲取文檔的元數(shù)據(jù),如標(biāo)題,創(chuàng)建者,創(chuàng)建日期等

    • sheetnames:獲取工作簿中的表(列表)

    部分方法如下:

    • get_sheet_names:獲取所有表格的名稱(chēng)(新版已經(jīng)不建議使用,通過(guò)Workbook的sheetnames屬性即可獲取)

    • get_sheet_by_name:通過(guò)表格名稱(chēng)獲取Worksheet對(duì)象(新版也不建議使用,通過(guò)Worksheet[‘表名’]獲取)

    • get_active_sheet:獲取活躍的表格(新版建議通過(guò)active屬性獲取)

    • remove_sheet:刪除一個(gè)表格

    • create_sheet:創(chuàng)建一個(gè)空的表格

    • copy_worksheet:在Workbook內(nèi)拷貝表格

    讀取

    from openpyxl import load_workbook
    # openpyxl.load_workbook()打開(kāi)已有工作簿
    wb = load_workbook('Eric.xlsx')
    # 打印工作簿中存在的工作表名稱(chēng)
    print(wb.sheetnames)
    # 根據(jù)名稱(chēng)獲取工作表
    sheet = wb['sheet1']
    # 如果只有一個(gè)工作表也可以如下
    sheet = wb.active
    # 讀取表格內(nèi)容所在范圍
    sheet.dimensions
    # 獲取單元格內(nèi)容
    # 指定坐標(biāo)
    cell = sheet['A1']
    # 指定行列
    cell = sheet.cell(row=3, column=4)
    # 打印單元格的值
    print(cell.value)
    # 獲取單元格的行、列、坐標(biāo)
    print(cell.row, cell.column, cell.coordinate)
    # 獲取范圍單元格的值
    # 指定坐標(biāo)范圍
    cells = sheet['A1':'C3']
    # 指定列范圍
    cells = sheet['A:C'] # cells = sheet['A']
    # 指定行范圍
    cells = sheet[2:5] # cells = sheet[3]
    # 遍歷獲取單元格的值
    for cell in cells:
        print(cell.value)
    # 特定范圍
    for row in sheet.iter_rows(min_row = 1, max_row = 10
                              min_col = 1, max_col = 26):
        print(row)
        # 遍歷獲取單元格的值
        for cell in row:
            print(cell.value)
    # 讀取所有行
    for row in sheet.rows:
        print(row)

    關(guān)于“Python操作Excel方法中openpyxl怎么用”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“Python操作Excel方法中openpyxl怎么用”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

    向AI問(wèn)一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI