


La lutte pour trouver un convertisseur Excel en PDF gratuit?: mon parcours et ma solution
Jan 12, 2025 pm 04:05 PMDe 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 tache 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 http://m.miracleart.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

Undress AI Tool
Images de déshabillage gratuites

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.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à 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

GO compile le programme dans un binaire autonome par défaut, la raison principale est la liaison statique. 1. Déploiement plus simple: aucune installation supplémentaire de bibliothèques de dépendances, ne peut être exécutée directement sur les distributions Linux; 2. 3. Prévisibilité et sécurité plus élevées: éviter les risques provoqués par les changements dans les versions externes de la bibliothèque et améliorer la stabilité; 4. Flexibilité de fonctionnement limitée: Impossible de mise à jour à chaud des bibliothèques partagées, et se recompiler et le déploiement sont nécessaires pour corriger les vulnérabilités de dépendance. Ces fonctionnalités sont adaptées aux outils CLI, aux microservices et à d'autres scénarios, mais des compromis sont nécessaires dans les environnements où le stockage est restreint ou repose sur une gestion centralisée.

Pour créer un canal tampon dans GO, spécifiez simplement les paramètres de capacité dans la fonction de faire. Le canal tampon permet à l'opération d'envoi de stocker temporairement les données en cas de récepteur, tant que la capacité spécifiée n'est pas dépassée. Par exemple, Ch: = Make (Chanint, 10) crée un canal tampon qui peut stocker jusqu'à 10 valeurs entières; Contrairement aux canaux non frappés, les données ne seront pas bloquées immédiatement lors de l'envoi, mais les données seront temporairement stockées dans le tampon jusqu'à ce qu'elles soient enlevées par le récepteur; Lorsque vous l'utilisez, veuillez noter: 1. Le réglage de la capacité doit être raisonnable pour éviter les déchets de mémoire ou le blocage fréquent; 2. Le tampon doit empêcher l'accumulation de problèmes de mémoire indéfiniment dans le tampon; 3. Le signal peut être passé par le type de chantruct {} pour enregistrer les ressources; Les scénarios courants incluent le contr?le du nombre de modèles de concurrence et de consommation producteur et de différenciation

GoEnsuresMemorySafetywithoutmanual Management ThroughhroughAutomaticGarBageCollection, nopointeraRITHMetic, SafeConcurrency, AndruntimeCkecks.first, Go’sgarBageColEctorAutomAccilmatmestsunusedMemory, empêchant le sanddanglingpoiners.

GO est idéal pour la programmation système car il combine les performances des langages compilés tels que C avec la facilité d'utilisation et la sécurité des langages modernes. 1. En termes d'opérations de fichiers et de répertoires, le package OS de GO prend en charge la création, la suppression, le renommage et la vérification si les fichiers et les répertoires existent. Utilisez OS.Readfile pour lire l'intégralité du fichier dans une ligne de code, qui convient à l'écriture de scripts de sauvegarde ou d'outils de traitement de journal; 2. 3. En termes de réseau et de concurrence, le package net prend en charge la programmation TCP / UDP, la requête DNS et les ensembles originaux.

Dans le langage GO, l'appel d'une méthode de structure nécessite d'abord de définir la structure et la méthode qui lie le récepteur et l'accès à l'aide d'un numéro de point. Après avoir défini le rectangle de structure, la méthode peut être déclarée via le récepteur de valeur ou le récepteur de pointeur; 1. Utilisez le récepteur de valeur tel que Func (Rrectangle) Area () Int et appelez directement-le via rect.area (); 2. Si vous avez besoin de modifier la structure, utilisez le récepteur de pointeur tel que SetWidth (R * rectangle) de Func (R * R * 3. Lors de l'intégration de la structure, la méthode de structure intégrée sera améliorée et peut être appelée directement par la structure extérieure; 4. GO n'a pas besoin de forcer l'utilisation de Getter / Setter,

Dans GO, une interface est un type qui définit le comportement sans spécifier l'implémentation. Une interface se compose de signatures de méthode, et tout type qui implémente ces méthodes satisfait automatiquement l'interface. Par exemple, si vous définissez une interface de haut-parleur contenant la méthode Speak (), tous les types qui implémentent la méthode peuvent être considérés comme haut-parleur. Les interfaces conviennent à la rédaction de fonctions communes, aux détails de l'implémentation abstrait et à l'utilisation d'objets simulés dans les tests. La définition d'une interface utilise le mot-clé d'interface et répertorie les signatures de la méthode, sans déclarer explicitement le type pour implémenter l'interface. Les cas d'utilisation courants incluent les journaux, le formatage, les abstractions de différentes bases de données ou services et des systèmes de notification. Par exemple, les types de chiens et de robots peuvent implémenter des méthodes Speak et les transmettre à la même Anno

Dans le langage GO, les opérations de cha?ne sont principalement implémentées via le package des cha?nes et les fonctions intégrées. 1.Strings.Contains () est utilisé pour déterminer si une cha?ne contient une sous-cha?ne et renvoie une valeur booléenne; 2.Strings.Index () peut trouver l'emplacement où la sous-cha?ne appara?t pour la première fois, et s'il n'existe pas, il renvoie -1; 3.Strings.ReplaceALL () peut remplacer toutes les sous-cha?nes correspondantes et peut également contr?ler le nombre de remplacements via des cha?nes.replace (); 4.Len () La fonction est utilisée pour obtenir la longueur des octets de la cha?ne, mais lors du traitement de l'Unicode, vous devez prêter attention à la différence entre les caractères et les octets. Ces fonctions sont souvent utilisées dans des scénarios tels que le filtrage des données, l'analyse de texte et le traitement des cha?nes.

ThegoiopackageProvidesInterfacesLikeReaderAndWritertoHandlei / Ooperations UniformlyAcrossources.1.io.Reader'sreadMethoDenablesReadingFromvariousSourcesuchasFilesorHttpResponsses.2.Io.writer'swritethodfacilita
