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

Python使用openpyxl模塊處理Excel文件

 更新時(shí)間:2022年06月03日 10:45:33   作者:springsnow  
這篇文章介紹了Python使用openpyxl模塊處理Excel文件的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

首先貼出四種方法適用范圍比較:

注釋:Excel 2003 即XLS文件有大小限制即65536行256列,所以不支持大文件。而Excel 2007以上即XLSX文件的限制則為1048576行16384列

一、xlutils & xlrd & xlwt

最原始的莫過(guò)于兩位老牌黃金搭檔xlrd xlwt了,針對(duì)二者的封裝有如下模塊:

為什么把這三個(gè)一起說(shuō)?

首先,xlutils封裝了xlrd xlwt,所以在使用前,會(huì)先下載這兩個(gè)依賴的模塊。

其次,這兩個(gè)模塊主要用于處理xls文件,而對(duì)xlsx的文件處理很挫,甚至xlwt不支持…

但為何到現(xiàn)在依然在使用這些模塊,因?yàn)樗麑?duì)xls文檔處理的優(yōu)勢(shì)….

1、xlutils

官方文檔:https://xlutils.readthedocs.io/en/latest/api.html

github項(xiàng)目:https://github.com/python-excel/xlutils

安裝:(如果沒(méi)安裝xlrd、xlwt,會(huì)自動(dòng)安裝這2個(gè)模塊)

pip install xlutils

使用:

import xlrd
import xlwt
import xlutils

import xlutils.copy as copy

rdbook = xlrd.open_workbook('first.xls')
wtbook = copy.copy(rdbook)
wtsheet = wtbook.get_sheet(0)
type(wtsheet)
wtsheet.write(0,0,'pcat.cc')
wtbook.save('second.xls')

2、xlrd

xlrd is a library for reading data and formatting information from Excel files, whether they are .xls or .xlsx files.

官方文檔:https://xlrd.readthedocs.io/en/latest/api.html

github項(xiàng)目:https://github.com/python-excel/xlrd

安裝:pip install xlrd

使用:只能讀.xls、.xlsx文件(xlrd0.8.0+版本支持讀取xlsx文件)

import xlrd
book = xlrd.open_workbook("pcat.xls")
print("The number of worksheets is {0}".format(book.nsheets))
print("Worksheet name(s): {0}".format(book.sheet_names()))
sh = book.sheet_by_index(0)
print("{0} {1} {2}".format(sh.name, sh.nrows, sh.ncols))
print("Cell B3 is {0}".format(sh.cell_value(rowx=2, colx=1)))
for rx in range(sh.nrows):
    print(sh.row(rx))

3、xlwt

xlwt is a library for writing data and formatting information to older Excel files (ie: .xls)

官方文檔:https://xlwt.readthedocs.io/en/latest/api.html

github項(xiàng)目:https://github.com/python-excel/xlwt

安裝:pip install xlwt

使用:用xlwt創(chuàng)建一個(gè)簡(jiǎn)單的.xls文件

import xlwt
from datetime import datetime

style0 = xlwt.easyxf('font: name Times New Roman, color-index red, bold on',
    num_format_str='#,##0.00')
style1 = xlwt.easyxf(num_format_str='YYYY-MM-DD HH:MM:SS')

wb = xlwt.Workbook()
ws = wb.add_sheet('A Test Sheet')

ws.write(0, 0, 1234.56, style0)
ws.write(1, 0, datetime.now(), style1)
ws.write(2, 0, 1)
ws.write(2, 1, 1)
ws.write(2, 2, xlwt.Formula("A3+B3"))

wb.save('example.xls')

二、pandas(推薦)

pandas

https://www.pypandas.cn/

pandas作為數(shù)據(jù)分析利器,在讀寫excel方面,依賴庫(kù)xlrd和xlwt。

import   pandas   as pd
 
#方法一:默認(rèn)讀取第一個(gè)表單
df=pd.read_excel('lemon.xlsx')#這個(gè)會(huì)直接默認(rèn)讀取到這個(gè)Excel的第一個(gè)表單
data=df.head()#默認(rèn)讀取前5行的數(shù)據(jù)
print("獲取到所有的值:\n{0}".format(data))#格式化輸出
 
#方法二:通過(guò)指定表單名的方式來(lái)讀取
df=pd.read_excel('lemon.xlsx',sheet_name='student')#可以通過(guò)sheet_name來(lái)指定讀取的表單
data=df.head()#默認(rèn)讀取前5行的數(shù)據(jù)
print("獲取到所有的值:\n{0}".format(data))#格式化輸出
 
#方法三:通過(guò)表單索引來(lái)指定要訪問(wèn)的表單,0表示第一個(gè)表單
#也可以采用表單名和索引的雙重方式來(lái)定位表單
#也可以同時(shí)定位多個(gè)表單,方式都羅列如下所示
df=pd.read_excel('lemon.xlsx',sheet_name=['python','student'])#可以通過(guò)表單名同時(shí)指定多個(gè)
# df=pd.read_excel('lemon.xlsx',sheet_name=0)#可以通過(guò)表單索引來(lái)指定讀取的表單
# df=pd.read_excel('lemon.xlsx',sheet_name=['python',1])#可以混合的方式來(lái)指定
# df=pd.read_excel('lemon.xlsx',sheet_name=[1,2])#可以通過(guò)索引 同時(shí)指定多個(gè)
data=df.values#獲取所有的數(shù)據(jù),注意這里不能用head()方法哦~
print("獲取到所有的值:\n{0}".format(data))#格式化輸出

三、xlsxwriter

https://xlsxwriter.readthedocs.io/

xlsxwriter擁有豐富的特性,支持圖片/表格/圖表/篩選/格式/公式等,功能與openpyxl相似,優(yōu)點(diǎn)是相比 openpyxl 還支持 VBA 文件導(dǎo)入,迷你圖等功能,缺點(diǎn)是不能打開(kāi)/修改已有文件,意味著使用 xlsxwriter 需要從零開(kāi)始。

注意:XlsxWriter不支持.xls格式。

代碼示例:

import xlsxwriter
 
# Create a workbook and add a worksheet.
workbook = xlsxwriter.Workbook('Expenses01.xlsx')
worksheet = workbook.add_worksheet()
 
# Some data we want to write to the worksheet.
expenses = (['Rent', 1000], ['Gas',     100],['Food',   300], ['Gym',       50],)
 
# Start from the first cell. Rows and columns are zero indexed.
row = 0
col = 0
 
# Iterate over the data and write it out row by row.
for item, cost in (expenses):       
   worksheet.write(row, col,     item)       
   worksheet.write(row, col + 1, cost)       
   row += 1
 
# Write a total using a formula.
worksheet.write(row, 0, 'Total')
worksheet.write(row, 1, '=SUM(B1:B4)')
worksheet.write('A1', 'Hello world')

workbook.close()

四、openpyxl(推薦)

讀寫 Excel 2010 xlsx/xlsm files.

最后要說(shuō)說(shuō)個(gè)人比較常用,也很方便的一個(gè)excel處理模塊openpyxl….這個(gè)模塊突出的優(yōu)勢(shì)在于,對(duì)excel單元格樣式的設(shè)置方面特別詳細(xì)。

注意:openpyxl不支持.xls格式。讀寫文件前記得多備注,有時(shí)候可能有bug。

官方文檔:https://openpyxl.readthedocs.io/en/stable/

安裝:pip install openpyxl

1、寫一個(gè)工作簿

from openpyxl import Workbook
from openpyxl.utils import get_column_letter

wb = Workbook()
dest_filename = 'empty_book.xlsx'

ws1 = wb.active
ws1.title = "range names"

for row in range(1, 40):  
   ws1.append(range(600))

ws2 = wb.create_sheet(title="Pi")
ws2['F5'] = 3.14
ws2['A1'] = 42  # Data can be assigned directly to cells
ws2.append([1, 2, 3])# Rows can also be appended

# Python types will automatically be converted
import datetime
ws2['A2'] = datetime.datetime.now()

ws3 = wb.create_sheet(title="Data")
for row in range(10, 20):     
  for col in range(27, 54):         
     _ = ws3.cell(column=col, row=row, value="{0}".format(get_column_letter(col)))
print(ws3['AA10'].value)

wb.save(filename = dest_filename)

2、讀取現(xiàn)有工作簿

from openpyxl import load_workbook

wb = load_workbook(filename = 'empty_book.xlsx')
sheet_ranges = wb['Sheet1']
print(sheet_ranges['D18'].value)

3.、插入圖像 (需要依賴pillow..)

from openpyxl import Workbook
from openpyxl.drawing.image import Image
 
wb = Workbook()
ws = wb.active
ws['A1'] = 'You should see three logos below'
img = Image('logo.png') # create an image
ws.add_image(img, 'A1') # add to worksheet and anchor next to cells
wb.save('logo.xlsx')

4、使用樣式

樣式用于在屏幕上顯示時(shí)更改數(shù)據(jù)的外觀。它們還用于確定數(shù)字的格式。

樣式可以應(yīng)用于以下方面:

  • 字體設(shè)置字體大小,顏色,下劃線等
  • 填充以設(shè)置圖案或顏色漸變
  • 邊框設(shè)置單元格上的邊框
  • 單元格排列
  • 保護(hù)

以下是默認(rèn)值:

from openpyxl.styles import PatternFill, Border, Side, Alignment, Protection, Font

font = Font(name='Calibri',size=11,bold=False, italic=False,vertAlign=None,underline='none',strike=False, color='FF000000')
fill = PatternFill(fill_type=None, start_color='FFFFFFFF', end_color='FF000000')
border = Border(left=Side(border_style=None,color='FF000000'),   right=Side(border_style=None,color='FF000000'), 
     top=Side(border_style=None, color='FF000000'), bottom=Side(border_style=None, color='FF000000'), 
                 diagonal=Side(border_style=None, color='FF000000'), diagonal_direction=0,   outline=Side(border_style=None,color='FF000000'), 
                 vertical=Side(border_style=None,color='FF000000'),   horizontal=Side(border_style=None,color='FF000000') )
alignment=Alignment(horizontal='general',vertical='bottom',   text_rotation=0, wrap_text=False,   shrink_to_fit=False, indent=0)
number_format = 'General'
protection = Protection(locked=True,   hidden=False)

到此這篇關(guān)于Python使用openpyxl模塊處理Excel文件的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 如何通過(guò)python實(shí)現(xiàn)人臉識(shí)別驗(yàn)證

    如何通過(guò)python實(shí)現(xiàn)人臉識(shí)別驗(yàn)證

    這篇文章主要介紹了如何通過(guò)python實(shí)現(xiàn)人臉識(shí)別驗(yàn)證,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • selenium3+python3環(huán)境搭建教程圖解

    selenium3+python3環(huán)境搭建教程圖解

    這篇文章主要介紹了selenium3+python3環(huán)境搭建教程圖解,需要的朋友可以參考下
    2018-12-12
  • python-django中的APPEND_SLASH實(shí)現(xiàn)方法

    python-django中的APPEND_SLASH實(shí)現(xiàn)方法

    這篇文章主要介紹了python-django中的APPEND_SLASH實(shí)現(xiàn)方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-06-06
  • 在?Python?中使用通配符匹配字符串的方法

    在?Python?中使用通配符匹配字符串的方法

    這篇文章主要介紹了在?Python?中使用通配符匹配字符串的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • Python使用pandas處理CSV文件的實(shí)例講解

    Python使用pandas處理CSV文件的實(shí)例講解

    今天小編就為大家分享一篇Python使用pandas處理CSV文件的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • python線程信號(hào)量semaphore使用解析

    python線程信號(hào)量semaphore使用解析

    這篇文章主要介紹了python線程信號(hào)量semaphore使用解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • Python實(shí)戰(zhàn)之外星人入侵游戲示例代碼

    Python實(shí)戰(zhàn)之外星人入侵游戲示例代碼

    這篇文章主要介紹了利用Python編寫的外星人入侵游戲的示例代碼,文中的代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python有一定的幫助,感興趣的可以學(xué)習(xí)一下
    2022-01-01
  • DataFrame.groupby()所見(jiàn)的各種用法詳解

    DataFrame.groupby()所見(jiàn)的各種用法詳解

    這篇文章主要介紹了DataFrame.groupby()所見(jiàn)的各種用法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Python 中Pickle庫(kù)的使用詳解

    Python 中Pickle庫(kù)的使用詳解

    pickle是python語(yǔ)言的一個(gè)標(biāo)準(zhǔn)模塊,安裝python后已包含pickle庫(kù),不需要單獨(dú)再安裝。這篇文章主要介紹了Python 中Pickle庫(kù)的使用詳解,需要的朋友可以參考下
    2018-02-02
  • python詞云庫(kù)wordCloud使用方法詳解(解決中文亂碼)

    python詞云庫(kù)wordCloud使用方法詳解(解決中文亂碼)

    這篇文章主要介紹了python詞云庫(kù)wordCloud使用方法詳解(解決中文亂碼),需要的朋友可以參考下
    2020-02-02

最新評(píng)論