


Un article expliquant en détail comment Golang génère des documents Excel
Cet article vous apporte des connaissances pertinentes sur Golang. Il présente principalement comment utiliser Golang pour générer des documents Excel. Les amis intéressés peuvent jeter un œil ci-dessous. J'espère que cela sera utile à tout le monde.
La génération de documents Excel basés sur des données est une exigence très courante. Cet article présentera comment utiliser la bibliothèque Excelize de Go pour générer des documents Excel, ainsi que les implémentations de code dans certains scénarios spécifiques.
À propos de la bibliothèque Excelize
Excelize
est une bibliothèque de base écrite en langage Go pour exploiter les documents Office Excel, basée sur les normes internationales ECMA-376, ISO/IEC 29500. Vous pouvez l'utiliser pour lire et écrire des feuilles de calcul créées avec Microsoft Excel™ 2007 et supérieur. Il prend en charge plusieurs formats de documents tels que XLSX / XLSM / XLTM / Data workbook. Il peut être appliqué à diverses plates-formes de rapports, au cloud computing, à l'informatique de pointe et à d'autres systèmes. L'utilisation de cette bibliothèque nécessite la version 1.15 ou supérieure du langage Go. Excelize
是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。支持 XLSX / XLSM / XLTM / XLTX 等多种文档格式,高度兼容带有样式、图片(表)、透视表、切片器等复杂组件的文档,并提供流式读写 API,用于处理包含大规模数据的工作簿。可应用于各类报表平台、云计算、边缘计算等系统。使用本类库要求使用的 Go 语言为 1.15 或更高版本。
性能对比
下图是一些主要的开源 Excel 库在生成 12800*50 纯文本矩阵时的性能对比(OS: macOS Mojave version 10.14.4, CPU: 3.4 GHz Intel Core i5, RAM: 16 GB 2400 MHz DDR4, HDD: 1 TB),包括 Go、Python、Java、PHP 和 NodeJS。
安装
最新的版本是 v2.4.0
:
go get github.com/360EntSecGroup-Skylar/excelize/v2
创建 Excel 文档
下面的案例中,我们创建了一个 Excel 文档,并使用 NewSheet
方法新建了一个 Sheet2
工作表,Sheet1
是默认创建的工作表,然后我们使用 SetCellValue
方法分别在 Sheet2
工作表的 A2
单元格 和 Sheet1
表格的 B2
单元格设置值,并通过使用 SetActiveSheet
方法设置 Sheet2
工作表为默认的工作表,最终调用 SaveAs
方法将数据写入 Excel 文档中:
package main import ( "fmt" "github.com/360EntSecGroup-Skylar/excelize/v2" ) func main() { f := excelize.NewFile() // 创建一个工作表 index := f.NewSheet("Sheet2") // 设置单元格的值 f.SetCellValue("Sheet2", "A2", "Hello world.") f.SetCellValue("Sheet1", "B2", 100) // 设置工作簿的默认工作表 f.SetActiveSheet(index) // 根据指定路径保存文件 if err := f.SaveAs("Book1.xlsx"); err != nil { fmt.Println(err) } }
实际场景复现
创建工作表
工作表名称是大小写敏感的:
index := f.NewSheet("Sheet2")
删除默认创建的工作表
默认创建的 Excel 文档是包含一个名为 Sheet1
的工作表,我们可能并不需要这个默认工作表,这个时候我们可以删除这个工作表:
f.DeleteSheet("Sheet1")
合并单元格
合并 Sheet1
工作表上 F1:I2
区域内的单元格:
excel.MergeCell("Sheet1", "F1", "I2")
单元格样式
给单元格设置样式会经常遇到,比如设置单元格的背景颜色,Excelize
库提供下面两个方法进行设置单元格样式(NewStyle
和 SetCellStyle
):
// 通过给定的样式格式 JSON 或结构体的指针创建样式并返回样式索引。 // 请注意,颜色需要使用 RGB 色域代码表示。 style, err := f.NewStyle(`{ "border": [ { "type": "left", "color": "0000FF", "style": 3 }, { "type": "top", "color": "00FF00", "style": 4 }, { "type": "bottom", "color": "FFFF00", "style": 5 }, { "type": "right", "color": "FF0000", "style": 6 }, { "type": "diagonalDown", "color": "A020F0", "style": 7 }, { "type": "diagonalUp", "color": "A020F0", "style": 8 }] }`) if err != nil { fmt.Println(err) } err = f.SetCellStyle("Sheet1", "D7", "D7", style)
文字水平居中
文字水平居中需要用到 Alignment
样式结构体:
type Alignment struct { Horizontal string `json:"horizontal"` Indent int `json:"indent"` JustifyLastLine bool `json:"justify_last_line"` ReadingOrder uint64 `json:"reading_order"` RelativeIndent int `json:"relative_indent"` ShrinkToFit bool `json:"shrink_to_fit"` TextRotation int `json:"text_rotation"` Vertical string `json:"vertical"` WrapText bool `json:"wrap_text"` }
水平居中只要设置 Horizontal
的值为 center
即可:
style, err := f.NewStyle(`{"alignment":{"horizontal":"center"}}`) if err != nil { fmt.Println(err) } err = excel.SetCellStyle("Sheet1", "B1", "B1", style)
给单元格设置纯色填充
给单元格填充颜色会使用到 Fill
样式结构体:
type Fill struct { Type string `json:"type"` Pattern int `json:"pattern"` Color []string `json:"color"` Shading int `json:"shading"` }
Style 结构体
从上面设置样式的代码中,我们可以发现 border
是一个数组,而 alignment
是一个结构体,这是由 Style
Comparaison des performances
La figure suivante montre la comparaison des performances de certaines principales bibliothèques Excel open source lors de la génération d'une matrice de texte brut 12800*50 (OS : macOS Mojave version 10.14 .4, CPU : Intel Core i5 à 3,4 GHz, RAM : 16 Go DDR4 à 2 400 MHz, disque dur : 1 To), y compris Go, Python, Java, PHP et NodeJS.
Installer 🎜🎜La dernière version est v2.4.0
: 🎜type Style struct {
Border []Border `json:"border"`
Fill Fill `json:"fill"`
Font *Font `json:"font"`
Alignment *Alignment `json:"alignment"`
Protection *Protection `json:"protection"`
NumFmt int `json:"number_format"`
DecimalPlaces int `json:"decimal_places"`
CustomNumFmt *string `json:"custom_number_format"`
Lang string `json:"lang"`
NegRed bool `json:"negred"`
}
Créer un document Excel 🎜🎜Dans le cas suivant, nous Nous avons créé un document Excel et utilisé la méthode NewSheet
pour créer une nouvelle feuille de calcul Sheet2
. Sheet1
est la feuille de calcul créée par défaut. Ensuite, nous utilisons SetCellValue est située dans la cellule A2
de la feuille de calcul Sheet2
et dans la cellule B2
de la Sheet1 code>. Définissez la valeur dans la cellule, définissez la feuille de calcul <code>Sheet2
comme feuille de calcul par défaut à l'aide de la méthode SetActiveSheet
, et enfin appelez la méthode SaveAs
. > méthode pour écrire les données dans Excel Dans le document : 🎜rrreeeReproduction du scénario réel🎜Créer une feuille de calcul
🎜Le nom de la feuille de calcul est sensible à la casse :🎜rrreeeSupprimer la feuille de calcul créée par défaut
🎜Le document Excel créé par défaut contient une feuille de calcul nommée Sheet1 code>, nous pouvons Cette feuille de calcul par défaut n'est pas nécessaire. Nous pouvons supprimer cette feuille de calcul pour le moment : 🎜rrreee<h3 id="Fusionner-les-cellules">Fusionner les cellules</h3>🎜Fusionner la <code>Feuille1 Feuille de calcul Cellules dans la zone supérieure <code>F1:I2
: 🎜rrreeeStyle de cellule
🎜La définition de styles pour les cellules est souvent rencontrée, comme Set la couleur d'arrière-plan de la cellule. La bibliothèque Excelize
fournit les deux méthodes suivantes pour définir le style de la cellule (NewStyle
et SetCellStyle
) : 🎜rrreeeCentrage horizontal du texte🎜Le centrage horizontal du texte nécessite une structure de style Alignement
: 🎜rrreee🎜Le centrage horizontal doit uniquement être défini sur Horizontal
La valeur est center
: 🎜rrreeeDéfinissez un remplissage de couleur unie pour la cellule
🎜Pour remplir la cellule de couleur, vous utiliserez Structure de style Fill
: 🎜rrreeeStructure de style
🎜À partir du code pour définir le style ci-dessus, nous pouvons trouver border code > est un tableau et <code>alignment
est une structure, qui est déterminée par la structure Style
: 🎜rrreee Recommandations associées : 🎜Go tutoriel vidéo🎜🎜
NewSheet
pour créer une nouvelle feuille de calcul Sheet2
. Sheet1
est la feuille de calcul créée par défaut. Ensuite, nous utilisons SetCellValue est située dans la cellule A2
de la feuille de calcul Sheet2
et dans la cellule B2
de la Sheet1 code>. Définissez la valeur dans la cellule, définissez la feuille de calcul <code>Sheet2
comme feuille de calcul par défaut à l'aide de la méthode SetActiveSheet
, et enfin appelez la méthode SaveAs
. > méthode pour écrire les données dans Excel Dans le document : 🎜rrreeeReproduction du scénario réel🎜Créer une feuille de calcul
🎜Le nom de la feuille de calcul est sensible à la casse :🎜rrreeeSupprimer la feuille de calcul créée par défaut
🎜Le document Excel créé par défaut contient une feuille de calcul nommée Sheet1 code>, nous pouvons Cette feuille de calcul par défaut n'est pas nécessaire. Nous pouvons supprimer cette feuille de calcul pour le moment : 🎜rrreee<h3 id="Fusionner-les-cellules">Fusionner les cellules</h3>🎜Fusionner la <code>Feuille1 Feuille de calcul Cellules dans la zone supérieure <code>F1:I2
: 🎜rrreeeStyle de cellule
🎜La définition de styles pour les cellules est souvent rencontrée, comme Set la couleur d'arrière-plan de la cellule. La bibliothèque Excelize
fournit les deux méthodes suivantes pour définir le style de la cellule (NewStyle
et SetCellStyle
) : 🎜rrreeeCentrage horizontal du texte🎜Le centrage horizontal du texte nécessite une structure de style Alignement
: 🎜rrreee🎜Le centrage horizontal doit uniquement être défini sur Horizontal
La valeur est center
: 🎜rrreeeDéfinissez un remplissage de couleur unie pour la cellule
🎜Pour remplir la cellule de couleur, vous utiliserez Structure de style Fill
: 🎜rrreeeStructure de style
🎜À partir du code pour définir le style ci-dessus, nous pouvons trouver border code > est un tableau et <code>alignment
est une structure, qui est déterminée par la structure Style
: 🎜rrreee Recommandations associées : 🎜Go tutoriel vidéo🎜🎜
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!

GOIMIMPACTSDEVENCEMENTSPOSITIVEMENTS INSPECT, EFFICACTION ET APPLICATION.1) VITESSE: GOCOMPILESQUICKLYANDRUNSEFFIÉMENT, IDEALFORLARGEPROROSTS.2) Efficacité: ITSCOMPEHENSIVESTANDARDLIBRARYREDUCEEXTERNEDENDENCES, EnhancingDevelovefficiency.3) Simplicité: Simplicité: Implicité de la manière

C est plus adapté aux scénarios où le contrôle direct des ressources matérielles et une optimisation élevée de performances sont nécessaires, tandis que Golang est plus adapté aux scénarios où un développement rapide et un traitement de concurrence élevé sont nécessaires. 1.C's Avantage est dans ses caractéristiques matérielles proches et à des capacités d'optimisation élevées, qui conviennent aux besoins de haute performance tels que le développement de jeux. 2. L'avantage de Golang réside dans sa syntaxe concise et son soutien à la concurrence naturelle, qui convient au développement élevé de services de concurrence.

Golang excelle dans les applications pratiques et est connu pour sa simplicité, son efficacité et sa concurrence. 1) La programmation simultanée est implémentée via des goroutines et des canaux, 2) le code flexible est écrit à l'aide d'interfaces et de polymorphismes, 3) Simplifier la programmation réseau avec des packages Net / HTTP, 4) Construire des robots concurrents efficaces, 5) Déboggage et optimisation par le biais d'outils et de meilleures pratiques.

Les caractéristiques principales de GO incluent la collection de déchets, la liaison statique et le support de concurrence. 1. Le modèle de concurrence du langage GO réalise une programmation concurrente efficace via le goroutine et le canal. 2. Les interfaces et les polymorphismes sont implémentés via des méthodes d'interface, de sorte que différents types peuvent être traités de manière unifiée. 3. L'utilisation de base démontre l'efficacité de la définition et de l'appel des fonctions. 4. Dans une utilisation avancée, les tranches offrent des fonctions puissantes de redimensionnement dynamique. 5. Des erreurs courantes telles que les conditions de course peuvent être détectées et résolues par l'imagerie. 6. Optimisation des performances Réutiliser les objets via Sync.Pool pour réduire la pression de collecte des ordures.

GO Language fonctionne bien dans la construction de systèmes efficaces et évolutifs. Ses avantages incluent: 1. Haute performance: compilé en code machine, vitesse de course rapide; 2. Programmation simultanée: simplifier le multitâche via les goroutines et les canaux; 3. Simplicité: syntaxe concise, réduction des coûts d'apprentissage et de maintenance; 4. Plate-forme multipliée: prend en charge la compilation multiplateforme, déploiement facile.

Confus quant au tri des résultats de la requête SQL. Dans le processus d'apprentissage de SQL, vous rencontrez souvent des problèmes déroutants. Récemment, l'auteur lit "Mick-SQL Basics" ...

La relation entre la convergence des piles technologiques et la sélection de la technologie dans le développement de logiciels, la sélection et la gestion des piles technologiques sont un problème très critique. Récemment, certains lecteurs ont proposé ...


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

SublimeText3 Linux nouvelle version
Dernière version de SublimeText3 Linux

Dreamweaver Mac
Outils de développement Web visuel

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

mPDF
mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

VSCode Windows 64 bits Télécharger
Un éditeur IDE gratuit et puissant lancé par Microsoft