Maison  >  Article  >  développement back-end  >  Tutoriel Python sur la lecture et l'écriture d'Excel avec openpyxl

Tutoriel Python sur la lecture et l'écriture d'Excel avec openpyxl

零下一度
零下一度original
2017-06-30 14:25:187808parcourir

Python utilise openpyxl pour lire et écrire des fichiers Excel

Il s'agit d'une bibliothèque tierce qui peut gérer les fichiers Excel au format xlsx. pip install openpyxlInstaller. Si vous utilisez Aanconda, il devrait l'accompagner.

La lecture de fichiers Excel

nécessite l'importation de fonctions associées.

from openpyxl import load_workbook# 默认可读写,若有需要可以指定write_only和read_only为Truewb = load_workbook('mainbuilding33.xlsx')

Le fichier ouvert par défaut est lisible et inscriptible. Si nécessaire, vous pouvez spécifier le paramètre read_only à True.

Obtenir la feuille--Feuille

# 获得所有sheet的名称print(wb.get_sheet_names())# 根据sheet名字获得sheeta_sheet = wb.get_sheet_by_name('Sheet1')# 获得sheet名print(a_sheet.title)# 获得当前正在显示的sheet, 也可以用wb.get_active_sheet()sheet = wb.active

Obtenir la cellule

# 获取某个单元格的值,观察excel发现也是先字母再数字的顺序,即先列再行b4 = sheet['B4']# 分别返回print(f'({b4.column}, {b4.row}) is {b4.value}')  # 返回的数字就是int型# 除了用下标的方式获得,还可以用cell函数, 换成数字,这个表示B2b4_too = sheet.cell(row=4, column=2)print(b4_too.value)

b4.columnRetourB , b4.row renvoie 4 et value est la valeur de cette cellule. De plus, la cellule a également un attribut coordinate. Les cellules comme b4 renvoient les coordonnées B4.

Obtenir le maximum de lignes et de colonnes

# 获得最大列和最大行print(sheet.max_row)print(sheet.max_column)

Obtenir la ligne et la colonne

  • sheet.rows est un générateur , À l'intérieur se trouvent les données de chaque ligne, et chaque ligne est enveloppée par un tuple.

  • sheet.columns est similaire, mais chaque tuple est une cellule dans chaque colonne.

# 因为按行,所以返回A1, B1, C1这样的顺序for row in sheet.rows:for cell in row:print(cell.value)# A1, A2, A3这样的顺序for column in sheet.columns:for cell in column:print(cell.value)

Le code ci-dessus peut obtenir les données de toutes les cellules. Que faire si vous souhaitez obtenir les données d'une certaine ligne ? Donnez-lui simplement un index. Parce que sheet.rows est un type générateur et ne peut pas utiliser d'index. Après l'avoir converti en liste, utilisez l'index pour obtenir l'objet tuple de la deuxième ligne. list(sheet.rows)[2]

for cell in list(sheet.rows)[2]:print(cell.value)
Comment obtenir des cellules dans n'importe quelle plage ?

Vous pouvez utiliser la fonction

. La méthode d'écriture suivante obtient toutes les cellules de la zone rectangulaire avec A1 comme coin supérieur gauche et B3 comme coin inférieur droit. rangeNotez que commence à 1, car dans openpyxl, afin d'être cohérent avec l'expression dans Excel, il n'est pas cohérent avec la convention des langages de programmation d'utiliser 0 pour représenter la première valeur. range

for i in range(1, 4):for j in range(1, 3):print(sheet.cell(row=i, column=j))        
# out<Cell mainbuilding33.A1><Cell mainbuilding33.B1><Cell mainbuilding33.A2><Cell mainbuilding33.B2><Cell mainbuilding33.A3><Cell mainbuilding33.B3>
peut également être utilisé comme des tranches.

Renvoie un tuple, qui est également un tuple à l'intérieur, composé de cellules dans chaque ligne. sheet['A1':'B3']

for row_cell in sheet[&#39;A1&#39;:&#39;B3&#39;]:for cell in row_cell:print(cell)        

for cell in sheet[&#39;A1&#39;:&#39;B3&#39;]:print(cell)# out(<Cell mainbuilding33.A1>, <Cell mainbuilding33.B1>)
(<Cell mainbuilding33.A2>, <Cell mainbuilding33.B2>)
(<Cell mainbuilding33.A3>, <Cell mainbuilding33.B3>)
Obtenir le numéro de colonne en fonction de la lettre et renvoyer la lettre en fonction du numéro de colonne

doit être importé, ces deux fonctions existent dans

openpyxl.utils

from openpyxl.utils import get_column_letter, column_index_from_string# 根据列的数字返回字母print(get_column_letter(2))  # B# 根据字母返回列的数字print(column_index_from_string(&#39;D&#39;))  # 4
Écrire des données dans Excel

Lié à la feuille de calcul

Besoin d'importer

WorkBook

from openpyxl import Workbook

wb = Workbook()
like this Une nouvelle feuille de calcul est créée (mais elle n'a pas encore été enregistrée).

Pour spécifier le

mode écriture seule, vous pouvez spécifier le paramètre . Généralement, le mode inscriptible et lisible par défaut est suffisant. write_only=True

print(wb.get_sheet_names())  # 提供一个默认名叫Sheet的表,office2016下新建提供默认Sheet1# 直接赋值就可以改工作表的名称sheet.title = &#39;Sheet1&#39;# 新建一个工作表,可以指定索引,适当安排其在工作簿中的位置wb.create_sheet(&#39;Data&#39;, index=1)  # 被安排到第二个工作表,index=0就是第一个位置# 删除某个工作表wb.remove(sheet)del wb[sheet]
Écrire dans des cellules

Vous pouvez également utiliser des formules

# 直接给单元格赋值就行sheet[&#39;A1&#39;] = &#39;good&#39;# B9处写入平均值sheet[&#39;B9&#39;] = &#39;=AVERAGE(B2:B8)&#39;

Mais si Quand lecture, vous devez ajouter pour que le nombre renvoyé après la lecture de B9 soit un nombre. Si vous n'ajoutez pas ce paramètre, la formule elle-même sera renvoyée '=AVERAGE(B2:B8)'data_only=True.

La fonction d'ajout

peut ajouter plusieurs lignes de données à la fois, en commençant par la première ligne vide (les lignes suivantes sont toutes des lignes vides).

# 添加一行row = [1 ,2, 3, 4, 5]
sheet.append(row)# 添加多行rows = [
    [&#39;Number&#39;, &#39;data1&#39;, &#39;data2&#39;],
    [2, 40, 30],
    [3, 40, 25],
    [4, 50, 30],
    [5, 30, 10],
    [6, 25, 5],
    [7, 50, 10],
]
Puisque la fonction

ne peut écrire que append ligne par ligne. Et si nous voulions écrire colonne par colonne. L'ajout peut-il répondre aux exigences ? Si vous considérez les listes imbriquées ci-dessus comme des matrices. Transposez simplement la matrice. Ceci peut être réalisé en utilisant la fonction , mais la liste interne devient un tuple. Ce sont tous des objets itérables et n’ont aucun effet. zip()

list(zip(*rows))# out[(&#39;Number&#39;, 2, 3, 4, 5, 6, 7),
 (&#39;data1&#39;, 40, 40, 50, 30, 25, 50),
 (&#39;data2&#39;, 30, 25, 30, 10, 5, 10)]
Expliquez ce qui précède
Tout d'abord

décomposez la liste, ce qui équivaut à remplir plusieurs paramètres list(zip(*rows))Extraire le chiffre 1 d'une liste 1. la valeur est combinée en un tuple, puis la deuxième valeur est extraite de chaque liste pour former un tuple, jusqu'à ce que la dernière valeur de la *rows liste la plus courte zip soit extraite, et les valeurs suivantes de la liste la plus longue soient est ignoré. En d'autres termes, le nombre final de tuples dans est déterminé par la longueur la plus courte de chaque paramètre d'origine (objet itérable). Par exemple, si vous supprimez une valeur à volonté, la longueur de liste la plus courte est de 2 et toutes les valeurs de la colonne data2 (visualisées verticalement) seront supprimées.

rows = [
    [&#39;Number&#39;, &#39;data1&#39;, &#39;data2&#39;],
    [2, 40],
    [3, 40, 25],
    [4, 50, 30],
    [5, 30, 10],
    [6, 25, 5],
    [7, 50, 10],
]# out[(&#39;Number&#39;, 2, 3, 4, 5, 6, 7), (&#39;data1&#39;, 40, 40, 50, 30, 25, 50)]
Enfin, zip renvoie un objet zip et les données ne sont pas visibles. Utilisez simplement
pour le convertir. Utilisez

pour écrire facilement des données dans des colonnes. listzipEnregistrez le fichier

Une fois toutes les opérations terminées, assurez-vous d'enregistrer le fichier. Précisez le chemin et le nom du fichier, avec le suffixe

.

xlsx

wb.save(r&#39;D:\example.xlsx&#39;)
Définir le style de cellule - Style

Importez d'abord les classes requises

from openpyxl.styles import Font, colors, AlignmentVous pouvez spécifier la police, la couleur et alignement.

Police

上面的代码指定了等线24号加粗斜体,字体颜色红色。直接使用cell的font属性,将Font对象赋值给它。

对齐方式

也是直接使用cell的属性aligment,这里指定垂直居中和水平居中。除了center,还可以使用right、left等等参数。

# 设置B1中的数据垂直居中和水平居中sheet[&#39;B1&#39;].alignment = Alignment(horizontal=&#39;center&#39;, vertical=&#39;center&#39;)

设置行高和列宽

有时候数据太长显示不完,就需要拉长拉高单元格。

# 第2行行高sheet.row_dimensions[2].height = 40# C列列宽sheet.column_dimensions[&#39;C&#39;].width = 30

合并和拆分单元格

所谓合并单元格,即以合并区域的左上角的那个单元格为基准,覆盖其他单元格使之称为一个大的单元格。

相反,拆分单元格后将这个大单元格的值返回到原来的左上角位置。

# 合并单元格, 往左上角写入数据即可sheet.merge_cells(&#39;B1:G1&#39;) # 合并一行中的几个单元格sheet.merge_cells(&#39;A1:C3&#39;) # 合并一个矩形区域中的单元格

合并后只可以往左上角写入数据,也就是区间中:左边的坐标。

如果这些要合并的单元格都有数据,只会保留左上角的数据,其他则丢弃。换句话说若合并前不是在左上角写入数据,合并后单元格中不会有数据。

以下是拆分单元格的代码。拆分后,值回到A1位置。

sheet.unmerge_cells(&#39;A1:C3&#39;)

这里就拿常用的说,具体的去看openpyxl文档

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn