


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://ipnx.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)

Golang est principalement utilisé pour le développement back-end, mais il peut également jouer un r?le indirect dans le champ frontal. Ses objectifs de conception se concentrent sur les hautes performances, le traitement simultané et la programmation au niveau du système, et conviennent à la création d'applications arrière telles que les serveurs API, les microservices, les systèmes distribués, les opérations de base de données et les outils CLI. Bien que Golang ne soit pas le langage grand public de la file d'attente Web, il peut être compilé en JavaScript via GOPHERJS, exécuter sur WebAssembly via Tinygo, ou générer des pages HTML avec un moteur de modèle pour participer au développement frontal. Cependant, le développement frontal moderne doit encore s'appuyer sur JavaScript / TypeScript et son écosystème. Par conséquent, Golang convient plus à la sélection de la pile technologique avec un backend haute performance comme noyau.

Pour construire un GraphQlapi en Go, il est recommandé d'utiliser la bibliothèque GQLGEN pour améliorer l'efficacité du développement. 1. Sélectionnez d'abord la bibliothèque appropriée, telle que GQLGEN, qui prend en charge la génération automatique de code basée sur le schéma; 2. Définissez ensuite GraphQlschema, décrivez la structure de l'API et le portail de requête, tels que la définition des types de post et des méthodes de requête; 3. Puis initialisez le projet et générez du code de base pour implémenter la logique métier dans Resolver; 4. Enfin, connectez GraphQlHandler à HttpServer et testez l'API via le terrain de jeu intégré. Les notes incluent les spécifications de dénomination des champs, la gestion des erreurs, l'optimisation des performances et les paramètres de sécurité pour assurer la maintenance du projet

La clé de l'installation de Go est de sélectionner la version correcte, de configurer les variables d'environnement et de vérifier l'installation. 1. Accédez au site officiel pour télécharger le package d'installation du système correspondant. Windows utilise des fichiers .msi, macOS utilise des fichiers .pkg, Linux utilise des fichiers .tar.gz et les décompressez vers / usr / répertoire local; 2. Configurer les variables d'environnement, modifier ~ / .Bashrc ou ~ / .zshrc dans Linux / macOS pour ajouter le chemin et Gopath, et Windows définit le chemin d'accès pour aller dans les propriétés du système; 3. Utilisez la commande gouvernementale pour vérifier l'installation et exécutez le programme de test Hello.go pour confirmer que la compilation et l'exécution sont normales. Paramètres et boucles de chemin tout au long du processus

Sync.WaitGroup est utilisé pour attendre qu'un groupe de Goroutines termine la tache. Son noyau est de travailler ensemble sur trois méthodes: ajouter, faire et attendre. 1.Add (n) Définissez le nombre de Goroutines à attendre; 2.Done () est appelé à la fin de chaque goroutine, et le nombre est réduit de un; 3.Wait () bloque la coroutine principale jusqu'à ce que toutes les taches soient effectuées. Lorsque vous l'utilisez, veuillez noter: ADD doit être appelé à l'extérieur du goroutine, évitez l'attente en double et assurez-vous de vous assurer que Don est appelé. Il est recommandé de l'utiliser avec un report. Il est courant dans la rampe simultanée des pages Web, du traitement des données par lots et d'autres scénarios, et peut contr?ler efficacement le processus de concurrence.

L'utilisation du package Embed de Go peut facilement intégrer des ressources statiques dans le binaire, adapté aux services Web pour emballer HTML, CSS, images et autres fichiers. 1. Déclarez la ressource intégrée à ajouter // Go: Embed Commentaire avant la variable, telle que l'intégration d'un seul fichier hello.txt; 2. Il peut être intégré dans l'ensemble du répertoire tel que statique / *, et réaliser des emballages multi-fichiers via ENGED.fs; 3. Il est recommandé de changer le mode de chargement du disque via des variables BuildTag ou Environment pour améliorer l'efficacité; 4. Faites attention à la précision du chemin, aux limitations de la taille des fichiers et aux caractéristiques en lecture seule des ressources intégrées. L'utilisation rationnelle de l'intégration peut simplifier le déploiement et optimiser la structure du projet.

Le c?ur du traitement audio et vidéo consiste à comprendre le processus de base et les méthodes d'optimisation. 1. Le processus de base comprend l'acquisition, le codage, la transmission, le décodage et la lecture, et chaque lien a des difficultés techniques; 2. Des problèmes courants tels que l'audio et l'aberration vidéo, le retard de latence, le bruit sonore, l'image floue, etc. peuvent être résolues par ajustement synchrone, optimisation de codage, module de réduction du bruit, ajustement des paramètres, etc.; 3. Il est recommandé d'utiliser FFMPEG, OpenCV, WebBrTC, GStreamer et d'autres outils pour atteindre des fonctions; 4. En termes de gestion des performances, nous devons prêter attention à l'accélération matérielle, à la définition raisonnable des fréquences d'images de résolution, à des problèmes de concurrence et de fuite de mémoire de contr?le. La ma?trise de ces points clés contribuera à améliorer l'efficacité du développement et l'expérience utilisateur.

Il n'est pas difficile de créer un serveur Web écrit en Go. Le noyau réside dans l'utilisation du package net / http pour implémenter des services de base. 1. Utilisez Net / HTTP pour démarrer le serveur le plus simple: enregistrez les fonctions de traitement et écoutez les ports via quelques lignes de code; 2. Gestion du routage: utilisez Servmux pour organiser plusieurs chemins d'interface pour une gestion structurée facile; 3. Pratiques communes: routage de groupe par modules fonctionnels et utiliser des bibliothèques tierces pour prendre en charge l'appariement complexe; 4. Service de fichiers statique: Fournissez des fichiers HTML, CSS et JS via HTTP.FileServer; 5. Performances et sécurité: activer HTTPS, limiter la taille du corps de la demande et définir le délai d'attente pour améliorer la sécurité et les performances. Après avoir ma?trisé ces points clés, il sera plus facile d'élargir les fonctionnalités.

Le but de Select Plus Default est de permettre à Select d'effectuer un comportement par défaut lorsqu'aucune autre branche n'est prête à éviter le blocage du programme. 1. Lorsque vous recevez des données du canal sans blocage, si le canal est vide, il entrera directement la branche par défaut; 2. En combinaison avec le temps. Après ou Ticker, essayez d'envoyer des données régulièrement. Si le canal est plein, il ne bloque pas et ne sautera pas; 3. Empêcher les blocs de bloces, éviter le programme coincé lorsqu'il est incertain si le canal est fermé; Lorsque vous l'utilisez, veuillez noter que la branche par défaut sera exécutée immédiatement et ne peut pas être abusée, et que par défaut et le cas s'excluent mutuellement et ne seront pas exécutés en même temps.
