IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Composants VCL Delphi Discussion :

Manipulation de fichiers Office ou LibreOffice dans Delphi


Sujet :

Composants VCL Delphi

  1. #1
    Membre du Club
    Profil pro
    chef de projet
    Inscrit en
    Septembre 2008
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : chef de projet

    Informations forums :
    Inscription : Septembre 2008
    Messages : 43
    Points : 49
    Points
    49
    Par défaut Manipulation de fichiers Office ou LibreOffice dans Delphi
    Bonjour,

    Je débute avec Delphi Community et je souhaite savoir s'il est possible de manipuler des documents Office et LibreOffice directement avec Delphi sans passer par la programmation OLE.
    De même est-il possible d'afficher ces documents à partir d'une application développée avec Delphi (idéalement sans devoir installer les outils bureautiques) ?
    En vous remerciant d'avance pour vos réponses.

    Fernando.

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    14 962
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 14 962
    Points : 40 794
    Points
    40 794
    Billets dans le blog
    62
    Par défaut
    Bonjour,

    Sans passer par OLE et sans installer a minima le SDK Office, non, je ne pense pas.
    D'un autre côté, je n'ai peut-être pas bien compris cette question sur OLE. Tout les programme que j'ai pu faire utilisant OpenOffice via Delphi ont été en créant un variant OpenOffice
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    OpenOffice := CreateOleObject('com.sun.star.ServiceManager');
    mais c'est vieux tout ça.

    Cela étant, comme il est écrit en préambule dans la FAQ chaque documentest un zip contenant plusieurs fichiers XML. Manipuler des zips et des XML c'est possible via Delphi. Avec des litres de sueurs il serait donc possible de ne pas passer par OLE
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  3. #3
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 377
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 13 377
    Points : 24 674
    Points
    24 674
    Par défaut
    Comme c'est du XML pour Office (compressé) c'est possible via un temps de développement énorme mais des Lib existe comme SmImport et SmExport pour lecture\écriture mais pas pour l'affichage.

    Pour l'affichage, il y a TMS Flexcel, je l'ai utilisé pour un projet, un peu délicat mais fonctionnel, justement sur un POS sans Office utilisant un Excel protégé pour la saisie de données.
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  4. #4
    Membre du Club
    Profil pro
    chef de projet
    Inscrit en
    Septembre 2008
    Messages
    43
    Détails du profil
    Informations personnelles :
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : chef de projet

    Informations forums :
    Inscription : Septembre 2008
    Messages : 43
    Points : 49
    Points
    49
    Par défaut
    Bonjour,

    J'ai trouvé en Free Pascal un composant FPSpreadsheet ( https://wiki.freepascal.org/FPSpreadsheet ) qui permet de piloter Excel sans plonger dans OLE (différentes versions d'Office, quid de LibreOffice,...).
    Mais pas de composant sur Word (ou Writer de LibreOffice)
    Il est vraiment étonnant qu'un IDE professionnel comme Delphi ne propose pas de base ces composants car il est rare de faire une application de gestion sans à un moment ou un autre manipuler des documents Office.

    Fernando.

  5. #5
    Expert confirmé
    Avatar de popo
    Homme Profil pro
    Analyste programmeur Delphi / C#
    Inscrit en
    Mars 2005
    Messages
    2 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Analyste programmeur Delphi / C#
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 2 626
    Points : 5 130
    Points
    5 130
    Par défaut
    J'ai dû géré moi même la génération de fichier Word, Excel et Writer et Calc sans OLE et avec uniquement ce qui est natif à Delphi 7.
    Donc je confirme, comme @ShaiLeTroll le suggère, qu'il s'agit en effet de XML archivé.

    Dans les faits, c'est un peu plus complexe car il y a plein de fichier XML et une arborescence de répertoire dans l'archive.
    Mais toutes cette mécanique répond à la nome Open XML qui est abondamment documentée.
    Donc, c'est pénible mais c'est faisable.

Discussions similaires

  1. [C#]Edition de fichiers office dans une winform
    Par cyrille_naert dans le forum Windows Forms
    Réponses: 2
    Dernier message: 02/01/2007, 17h50
  2. Code barre dans des fichiers QuiReport 3.62 pour delphi 7
    Par yanis97 dans le forum Composants VCL
    Réponses: 1
    Dernier message: 07/03/2006, 15h25
  3. ouverture de fichiers word dans delphi (sans utiliser word)
    Par poussinphp dans le forum API, COM et SDKs
    Réponses: 2
    Dernier message: 11/07/2005, 15h25
  4. [BIGINT dans Firebird] comment les manipuler dans Delphi ?
    Par kase74 dans le forum Bases de données
    Réponses: 4
    Dernier message: 30/08/2004, 12h11
  5. Réponses: 2
    Dernier message: 18/01/2003, 18h06

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo