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

Python openpyxl模塊學(xué)習(xí)之輕松玩轉(zhuǎn)Excel

 更新時間:2021年12月07日 10:13:25   作者:編程簡單學(xué)  
Python提供了許多操作Excel的模塊,能夠讓我們從繁瑣的工作中騰出雙手。本文主要為大家介紹的是openpyxl模塊,它的功能相對與其他模塊更為齊全,感興趣的小伙伴快來學(xué)習(xí)一下吧

前言

當(dāng)你需要每天對 Excel 做大量重復(fù)的操作,如果只靠人工來做既浪費時間,又十分枯燥,好在 Python 為我們提供了許多操作 Excel 的模塊,能夠讓我們從繁瑣的工作中騰出雙手。

今天就和大家分享一個快速處理 Excel 的模塊 openpyxl,它的功能相對與其他模塊更為齊全,足夠應(yīng)對日常出現(xiàn)的問題。

openpyxl 安裝

直接在命令提示符中輸入。

pip install openpyxl

或使用豆瓣鏡像安裝。

pip install -i https://pypi.douban.com/simple openpyxl

安裝成功后,下面就看看如何使用

打開/創(chuàng)建工作簿

示例工作簿?

工作表【一等獎】

工作表【二等獎】

(1)打開本地工作簿

>>> from openpyxl import load_workbook
>>> wb = load_workbook('獲獎名單.xlsx')

(2)創(chuàng)建空的工作薄

>>> from openpyxl import Workbook
>>> wb1 = Workbook()

訪問工作表

創(chuàng)建新工作表,可指定插入的位置(0:首位,-1:末尾)。

>>> wb.create_sheet('new_sheet', 0)
<Worksheet "new_sheet">

獲取工作簿中所有工作表。

>>> wb.sheetnames
['new_sheet', '一等獎', '二等獎']

使用列表推導(dǎo)式遍歷獲取所有工作表名稱。

>>> [sheet.title for sheet in wb]
['new_sheet', '一等獎', '二等獎']

使用 wb[sheetname] 來獲取一個工作表對象

>>> wb['二等獎']
<Worksheet "二等獎">

獲取活動表(即打開工作簿首先出現(xiàn)的工作表)。

>>> wb.active
<Worksheet "一等獎">

獲取工作表行列信息。

>>> sheet1 = wb['一等獎']
>>> sheet1.max_column
7
>>> sheet1.max_row
6

獲取單元格信息

訪問某個單元格

>>> sheet1['D3']
<Cell '一等獎'.D3>
>>> sheet1.cell(row=3, column=4)
<Cell '一等獎'.D3>

如果訪問單元格式添加 value 參數(shù)則會修改當(dāng)前單元格的值。

>>> sheet1.cell(3, 4).value
'基于Spark、Python的醫(yī)護(hù)人員信息抽取與管理'
>>> sheet1.cell(3, 4, value='Python')
<Cell '一等獎'.D3>
>>> sheet1.cell(3, 4).value
'Python'

獲取單元格的值、坐標(biāo)、行索引、列索引。

>>> sheet1['D3'].value
'Python'
>>> sheet1['D3'].coordinate
'D3'
>>> sheet1['D3'].row
3
>>> sheet1['D3'].column
4

訪問多個單元格

使用切片來訪問多個單元格,這里的切片與列表切片有區(qū)別,列表切片是前閉后開,Excel 中的切片是前閉后閉。

(1)選取 A1:B2 區(qū)域的單元格。

>>> sheet1['A1':'B2']
((<Cell '一等獎'.A1>,
  <Cell '一等獎'.B1>),
 (<Cell '一等獎'.A2>,
  <Cell '一等獎'.B2>))

選取單列數(shù)據(jù)。

>>> sheet1['D']
(<Cell '一等獎'.D1>,
    ...
 <Cell '一等獎'.D6>)

選取B,C列數(shù)據(jù)。

 >>> sheet1['B:C']
((<Cell '一等獎'.B1>,
    ...
  <Cell '一等獎'.B6>),
 (<Cell '一等獎'.C1>,
    ...
  <Cell '一等獎'.C6>))

選取單行數(shù)據(jù)。

>>> sheet1[3]
(<Cell '一等獎'.A3>,
 <Cell '一等獎'.B3>,
    ...
 <Cell '一等獎'.F3>,
 <Cell '一等獎'.G3>)

選取第2,3行數(shù)據(jù)。

>>> sheet1[2:3]
((<Cell '一等獎'.A2>,
    ...
  <Cell '一等獎'.G2>),
 (<Cell '一等獎'.A3>,
    ...
  <Cell '一等獎'.G3>))

遍歷獲取數(shù)據(jù)

按行遍歷指定范圍(B2:C3)數(shù)據(jù)。

>>> for row in  sheet1.iter_rows(min_row=2, max_row=3, min_col=2, max_col=3):
        for cell in  row:
            print(cell.coordinate)
 
B2
C2
B3
C3

按列遍歷指定范圍(B2:C3)數(shù)據(jù)。

>>> for col in  sheet1.iter_cols(min_row=2, max_row=3, min_col=2, max_col=3):
        for cell in col:
            print(cell.coordinate)
 
B2
B3
C2
C3

如果 iter_rows()/iter_cols() 中指定參數(shù) values_only=True,那么將只返回單元格的值

按行遍歷所有數(shù)據(jù)。

>>> tuple(sheet1.rows)
((<Cell '一等獎'.A1>,
  ...
  <Cell '一等獎'.G1>),
  ...
  ...
 (<Cell '一等獎'.A6>,
  ...
  <Cell '一等獎'.G6>))

按列遍歷所有數(shù)據(jù)。

>>> tuple(sheet1.columns)
((<Cell '一等獎'.A1>,
  ...
  <Cell '一等獎'.A6>),
  ...
  ...
 (<Cell '一等獎'.G1>, 
  ...
  <Cell '一等獎'.G6>))

修改工作表

單元格賦值

新增一列計算 作者 人數(shù)。

>>> for row_index in range(2, sheet1.max_row + 1):
	      sheet1.cell(row_index, 8).value = len(sheet1.cell(row_index, 6).value.split(','))

使用公式給單元格賦值,H7 統(tǒng)計作者總?cè)藬?shù)。

>>> sheet1['H7'] = '=SUM(H1:H6)'

追加一行數(shù)據(jù)

使用列表按序傳入值。

>>> sheet1.append([str(n) for n in range(6)])

使用字典指定 列索引:列值 。

>>> sheet1.append({'A':'1','C':'3'})

插入空白行

在指定位置插入空白行, idx 行索引,插入的位置;amount 插入空白行的數(shù)量

>>> sheet1.insert_rows(idx=2, amount=2)

刪除工作表

>>> wb.remove(wb['new_sheet'])

保存工作簿

>>> wb.save('獲獎名單V1.xlsx')

修改樣式

字體

設(shè)置 B2 單元格字體格式為,顏色可以用十六進(jìn)制顏色代碼。

>>> from openpyxl.styles import Font
 
>>> new_font = Font(name='微軟雅黑', size=20, color='3333CC', bold=True)
>>> sheet1['B2'].font = new_font

單元格背景顏色

>>> from openpyxl.styles import PatternFill, colors
>>> sheet1["A2"].fill = PatternFill("solid", fgColor=colors.BLUE)
>>> sheet1["A3"].fill = PatternFill("solid", fgColor='FF66CC')

對齊方式

設(shè)置 D2 中的數(shù)據(jù) 垂直居中 和 水平居中 。

>>> from openpyxl.styles import Alignment
>>> sheet1['D2'].alignment = Alignment(horizontal='center', vertical='center')

行高/列寬

設(shè)置第2行行高為40,C列列寬為20。

>>> sheet1.row_dimensions[2].height = 40
>>> sheet1.column_dimensions['C'].width = 20

合并/拆分單元格

合并單元格只需要指定左上角和右下角的單元格坐標(biāo)。

>>> sheet.merge_cells('A1:C3')

拆分單元格后,合并區(qū)域的值會賦給左上角單元格A1。

>>> sheet.unmerge_cells('A1:C3')

以上就是Python openpyxl模塊學(xué)習(xí)之輕松玩轉(zhuǎn)Excel的詳細(xì)內(nèi)容,更多關(guān)于Python openpyxl模塊的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • python使用tkinter實現(xiàn)屏幕中間倒計時

    python使用tkinter實現(xiàn)屏幕中間倒計時

    這篇文章主要為大家詳細(xì)介紹了python使用tkinter實現(xiàn)屏幕中間倒計時,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • python數(shù)組排序方法之sort、sorted和argsort詳解

    python數(shù)組排序方法之sort、sorted和argsort詳解

    這篇文章主要給大家介紹了關(guān)于python數(shù)組排序方法之sort、sorted和argsort的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2022-03-03
  • Python報表自動化之從數(shù)據(jù)到可視化一站式指南

    Python報表自動化之從數(shù)據(jù)到可視化一站式指南

    在現(xiàn)代數(shù)據(jù)驅(qū)動的世界中,生成清晰、有用的報表對于業(yè)務(wù)決策至關(guān)重要,Python作為一門強(qiáng)大的編程語言,提供了豐富的庫和工具,使得報表自動化變得輕而易舉,本文將詳細(xì)介紹如何利用Python從數(shù)據(jù)處理到可視化,實現(xiàn)報表自動化的全過程
    2024-01-01
  • Python 對Excel求和、合并居中的操作

    Python 對Excel求和、合并居中的操作

    這篇文章主要介紹了Python 對Excel求和、合并居中的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • 手把手教你在Pycharm中新建虛擬環(huán)境并使用(超詳細(xì)!)

    手把手教你在Pycharm中新建虛擬環(huán)境并使用(超詳細(xì)!)

    使用python開發(fā)項目通常都會創(chuàng)建一個虛擬環(huán)境,將項目依賴包安裝到虛擬環(huán)境中,避免一臺電腦上開發(fā)多個項目時依賴包版本號不兼容造成沖突,下面這篇文章主要給大家介紹了關(guān)于如何在Pycharm中新建虛擬環(huán)境并使用的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • 使用Pyparsing處理復(fù)雜文本實現(xiàn)過程

    使用Pyparsing處理復(fù)雜文本實現(xiàn)過程

    這篇文章主要為大家介紹了使用Pyparsing處理復(fù)雜文本的實現(xiàn)過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • Pycharm配置Qt Designer及Pyuic的實現(xiàn)方法

    Pycharm配置Qt Designer及Pyuic的實現(xiàn)方法

    本文介紹了如何安裝Qt designer和Pyuic以及他們的基本用法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • python3 sorted 如何實現(xiàn)自定義排序標(biāo)準(zhǔn)

    python3 sorted 如何實現(xiàn)自定義排序標(biāo)準(zhǔn)

    這篇文章主要介紹了python3 sorted 如何實現(xiàn)自定義排序標(biāo)準(zhǔn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • Windows系統(tǒng)下安裝Python的SSH模塊教程

    Windows系統(tǒng)下安裝Python的SSH模塊教程

    這篇文章主要介紹了Windows系統(tǒng)下安裝Python的SSH模塊教程,本文涵蓋了pycrypto、ecdsa、paramiko、OpenSSH、SSH等模塊的安裝,需要的朋友可以參考下
    2015-02-02
  • python 實現(xiàn)數(shù)字字符串左側(cè)補(bǔ)零的方法

    python 實現(xiàn)數(shù)字字符串左側(cè)補(bǔ)零的方法

    今天小編就為大家分享一篇python 實現(xiàn)數(shù)字字符串左側(cè)補(bǔ)零的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12

最新評論