


La lutte pour trouver un convertisseur Excel en PDF gratuit : mon parcours et ma solution
De nombreux projets nécessitent la conversion de fichiers Excel au format PDF, qu'il s'agisse de générer des rapports, de partager des données ou de créer des documents. Au départ, comme de nombreux développeurs, je pensais que ce serait une tâche facilement automatisée. Cependant, la recherche d’une solution gratuite et fiable est semée d’embûches : limitations, problèmes de compatibilité et outils commerciaux coûteux.
Finalement, j'ai surmonté ces difficultés et créé mon propre Convertisseur Excel en PDF et je l'ai rendu disponible en tant qu'outil open source à d'autres développeurs susceptibles d'être confrontés au même dilemme.
Expérience frustrante
Outils commerciaux
Les premiers résultats de recherche pointaient vers des solutions payantes telles que Aspose.Cells, Syncfusion et autres. Bien qu'ils soient puissants, leurs frais de licence sont élevés, ce qui les rend prohibitifs pour les petits projets ou les projets personnels.
Services en ligne
Les convertisseurs en ligne gratuits semblent être un bon choix, mais ils ne sont pas adaptés à l'automatisation. Ces outils présentent souvent des problèmes de confidentialité (car les fichiers sont téléchargés sur des serveurs tiers), des limitations de taille de fichier et ne fournissent pas d'API de programmation.
Bibliothèque Open Source
J'ai également exploré les bibliothèques open source, mais la plupart manquaient de fonctionnalités pour convertir des fichiers Excel en PDF. Même les bibliothèques dotées de cette fonctionnalité sont souvent peu fiables ou ne prennent pas en charge les formats Microsoft Office modernes.
LibreOffice en mode sans tête
Après quelques semaines de recherche, je suis tombé sur un moyen d'utiliser LibreOffice en mode sans tête. LibreOffice est une suite bureautique gratuite et open source qui peut convertir plusieurs formats de fichiers, dont Excel, en PDF. Lorsqu'il fonctionne en mode sans tête, il fonctionne via la ligne de commande, ce qui le rend idéal pour l'automatisation.
Comment fonctionne ma solution
Afin de faciliter l'utilisation par les développeurs, j'ai construit un serveur HTTP léger basé sur Go qui agit comme une API REST. Ce serveur encapsule les fonctionnalités de LibreOffice et permet à n'importe quel langage de programmation d'interagir avec lui via des requêtes HTTP.
Fonctions principales
- Prend en charge plusieurs formats de fichiers : prend en charge .xlsx, .xls, .csv, .docx, .pptx et d'autres formats.
- Nettoyage automatique : les fichiers temporaires sont automatiquement supprimés après une heure pour économiser de l'espace disque.
- Polices personnalisées : les polices personnalisées peuvent être installées en clonant le référentiel GitHub ou en utilisant un volume Docker.
- Intégration multilingue : fonctionne avec n'importe quel langage de programmation prenant en charge HTTP.
Méthode du répertoire temporaire
Au lieu de m'appuyer sur le répertoire temporaire du système, j'ai choisi d'utiliser un répertoire ./tmp personnalisé. Cela garantit un comportement cohérent puisque les répertoires temporaires du système ont parfois des autorisations imprévisibles.
Détails de mise en œuvre
Flux de travail
-
Téléchargement de fichiers : le client utilise le point de terminaison
/convert
pour télécharger des fichiers Excel via des requêtes POST. - Stockage temporaire : Le serveur enregistre les fichiers dans le répertoire ./tmp avec des noms de fichiers basés sur des horodatages.
- Convertir : appelez LibreOffice en mode sans tête pour convertir le fichier en PDF et enregistrez le résultat dans le même répertoire.
- Nettoyage de fichiers : la goroutine en arrière-plan supprime les fichiers datant de plus d'une heure.
- Réponse : renvoie le PDF converti sous forme de réponse HTTP.
Guide de démarrage
Dépôt GitHub
Vous pouvez trouver le code source sur https://www.php.cn/link/5b1add8961a1cfa07e60838ffd0f83e7.
Image Docker
Ce projet fournit également une image Docker : wteja/pdf-converter.
Exécuter le conteneur Docker
<code>docker pull wteja/pdf-converter docker run -p 5000:5000 wteja/pdf-converter</code>
Exemples d'intégration avec d'autres langages
Étant donné que le service est exposé via HTTP, vous pouvez interagir avec lui en utilisant n'importe quel langage de programmation.
C#
var client = new HttpClient(); var fileContent = new ByteArrayContent(File.ReadAllBytes("example.xlsx")); var formData = new MultipartFormDataContent { { fileContent, "file", "example.xlsx" } }; var response = await client.PostAsync("http://localhost:5000/convert", formData); var pdfBytes = await response.Content.ReadAsByteArrayAsync(); File.WriteAllBytes("output.pdf", pdfBytes);
Node.js
const axios = require("axios"); const FormData = require("form-data"); const fs = require("fs"); const form = new FormData(); form.append("file", fs.createReadStream("example.xlsx")); axios.post("http://localhost:5000/convert", form, { headers: form.getHeaders() }) .then(response => fs.writeFileSync("output.pdf", response.data)) .catch(console.error);
Python
import requests with open("example.xlsx", "rb") as f: response = requests.post("http://localhost:5000/convert", files={"file": f}) with open("output.pdf", "wb") as f: f.write(response.content)
Partez
package main import ( "bytes" "io" "mime/multipart" "net/http" "os" ) func main() { file, _ := os.Open("example.xlsx") defer file.Close() body := &bytes.Buffer{} writer := multipart.NewWriter(body) part, _ := writer.CreateFormFile("file", "example.xlsx") io.Copy(part, file) writer.Close() req, _ := http.NewRequest("POST", "http://localhost:5000/convert", body) req.Header.Set("Content-Type", writer.FormDataContentType()) resp, _ := http.DefaultClient.Do(req) defer resp.Body.Close() out, _ := os.Create("output.pdf") defer out.Close() io.Copy(out, resp.Body) }
Défis et compromis
Taille de l'image
En raison des dépendances de LibreOffice, la taille de l'image Docker est de 2,67 Go. Bien que j'aie testé des images plus petites telles qu'Alpine, elles contenaient des versions plus anciennes de LibreOffice qui n'étaient pas compatibles avec les formats Microsoft Office modernes. Bien que Debian fournisse la dernière version de LibreOffice, l'image générée est plus grande (environ 3 Go).
Pourquoi ça vaut le coup
La taille d'image plus grande est un compromis acceptable par rapport au coût des solutions commerciales. Une fois configurée, l'image peut être réutilisée dans plusieurs projets sans payer de frais de licence supplémentaires.
Conclusion
La frustration de trouver un convertisseur Excel vers PDF gratuit m'a amené à créer ma propre solution en utilisant LibreOffice en mode sans tête. Même s'il n'est pas parfait, il est gratuit, fiable et flexible. Si vous êtes confronté au même défi, j'espère que ce projet vous fera gagner du temps et des efforts.
Veuillez consulter le projet sur GitHub ou extraire l'image Docker de Docker Hub. S'il vous plaît laissez-moi savoir comment cela fonctionne pour vous ou si vous avez des suggestions d'améliorations.
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!

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

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

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

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds











Golang est meilleur que Python en termes de performances et d'évolutivité. 1) Les caractéristiques de type compilation de Golang et le modèle de concurrence efficace le font bien fonctionner dans des scénarios de concurrence élevés. 2) Python, en tant que langue interprétée, s'exécute lentement, mais peut optimiser les performances via des outils tels que Cython.

Golang est meilleur que C en concurrence, tandis que C est meilleur que Golang en vitesse brute. 1) Golang obtient une concurrence efficace par le goroutine et le canal, ce qui convient à la gestion d'un grand nombre de tâches simultanées. 2) C Grâce à l'optimisation du compilateur et à la bibliothèque standard, il offre des performances élevées près du matériel, adaptées aux applications qui nécessitent une optimisation extrême.

GOISIDEALFORBEGINNERNERS et combinant pour pourcloudandNetWorkServicesDuetOtssimplicity, Efficiency, andCurrencyFeatures.1) InstallgofromTheofficialwebsiteandverifywith'goversion'..2)

Golang convient au développement rapide et aux scénarios simultanés, et C convient aux scénarios où des performances extrêmes et un contrôle de bas niveau sont nécessaires. 1) Golang améliore les performances grâce à des mécanismes de collecte et de concurrence des ordures, et convient au développement de services Web à haute concurrence. 2) C réalise les performances ultimes grâce à la gestion manuelle de la mémoire et à l'optimisation du compilateur, et convient au développement du système intégré.

Golang et Python ont chacun leurs propres avantages: Golang convient aux performances élevées et à la programmation simultanée, tandis que Python convient à la science des données et au développement Web. Golang est connu pour son modèle de concurrence et ses performances efficaces, tandis que Python est connu pour sa syntaxe concise et son écosystème de bibliothèque riche.

Les différences de performance entre Golang et C se reflètent principalement dans la gestion de la mémoire, l'optimisation de la compilation et l'efficacité du temps d'exécution. 1) Le mécanisme de collecte des ordures de Golang est pratique mais peut affecter les performances, 2) la gestion manuelle de C et l'optimisation du compilateur sont plus efficaces dans l'informatique récursive.

Golang et C ont chacun leurs propres avantages dans les compétitions de performance: 1) Golang convient à une concurrence élevée et à un développement rapide, et 2) C fournit des performances plus élevées et un contrôle fin. La sélection doit être basée sur les exigences du projet et la pile de technologie d'équipe.

GolangisidealforBuildingsCalableSystemsDuetoitSefficiency and Concurrency, tandis que les Implicites de l'Indrecosystem et le Golang'sDesignenCourageSlecElNCORES
