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

C++ Discussion :

Lancer une application Excel à partir de C++


Sujet :

C++

  1. #1
    Membre confirmé
    Inscrit en
    Septembre 2006
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 113
    Par défaut Lancer une application Excel à partir de C++
    Bonjour,

    Je viens de tomber sur un article que je trouve intéressant (taper « A brief introduction to C++ and interfacing with Excel » Andrew L. Hazel sur Google).
    Dans ce document pdf, la dernière partie traite de comment utiliser Excel à partir de C++
    Je place le code ici qui est censé faire apparaître une fenetre excel à l’ecran lors de l’éxécution…
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
     
    //MicroSoft Office Objects
    #import \
    "C:\Program Files\Common Files\Microsoft Shared\OFFICE11\mso.dll" \
    rename("DocumentProperties", "DocumentPropertiesXL") \
    rename("RGB", "RBGXL")
    //Microsoft VBA Objects
    #import \
    "C:\Program Files\Common Files\Microsoft Shared\VBA\VBA6\vbe6ext.olb"
    //Excel Application Objects
    #import "C:\Program Files\Microsoft Office\OFFICE11\EXCEL.EXE" \
    rename("DialogBox", "DialogBoxXL") rename("RGB", "RBGXL") \
    rename("DocumentProperties", "DocumentPropertiesXL") \
    rename("ReplaceText", "ReplaceTextXL") \
    rename("CopyFile", "CopyFileXL") \
    exclude("IFont", "IPicture") no_dual_interfaces
     
    int main()
    {
    Excel::_ApplicationPtr XL;
    //A try block is used to trap any errors in communication
    try
    {
    //Initialise COM interface
    CoInitialize(NULL);
    //Start the Excel Application
    XL.CreateInstance(L"Excel.Application");
    //Make the Excel Application visible, so that we can see it!
    XL->Visible = true;
    }
    //If a communication error is thrown, catch it and complain
    catch(_com_error &error)
    {
    cout << "COM error " << endl;
    }
    }


    Evidemment si je poste, c’est pcq chez moi ca marche pas => je voulais savoir
    1/ si qqun pouvait tester chez lui et si ca marche chez lui, comment ca se fait ??
    2/ si ca ne marche pas, comment faire pour que ca marche..

    Merci d’avance
    DH

  2. #2
    Membre confirmé
    Inscrit en
    Septembre 2006
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 113
    Par défaut
    Voici le message d'errreur

    LIBC.lib(wincrt0.obj) : error LNK2001: unresolved external symbol _WinMain@16
    Release/Excel.exe : fatal error LNK1120: 1 unresolved externals

  3. #3
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 395
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    Crée un projet Application console.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  4. #4
    Membre confirmé
    Inscrit en
    Septembre 2006
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 113
    Par défaut
    okay désolé,

    j'avais créé un windows application => il faut un winmain et pas un main
    => en créant un console application sous VStudio 2003, ca marche très bien

    Je suis donc désolé et je m'excuse de vous avoir réveillé :-)
    dh

  5. #5
    Membre confirmé
    Inscrit en
    Septembre 2006
    Messages
    113
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 113
    Par défaut
    pas vu la réponse
    Merci beaucoup

  6. #6
    Membre confirmé Avatar de fullben
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    58
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2007
    Messages : 58
    Par défaut
    Citation Envoyé par dhoorens
    2/ si ca ne marche pas, comment faire pour que ca marche..
    Merci d’avance
    DH
    Dsl chez moi non plus ça marche pas mais je vais essayé de savoir pourquoi je dis bien essayé !!) je répond si j'ai trouvé !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Comment lancer une application a partir de ma ComboBox ?
    Par Hellgast dans le forum C++Builder
    Réponses: 14
    Dernier message: 27/03/2009, 17h04
  2. Lancer une Macro Excel à partir d'access
    Par ThieBEN dans le forum VBA Access
    Réponses: 8
    Dernier message: 12/12/2007, 14h21
  3. Réponses: 3
    Dernier message: 14/09/2007, 19h13
  4. Réponses: 2
    Dernier message: 10/07/2007, 13h45
  5. Lancer une application à partir du shell
    Par Spacy_green dans le forum Linux
    Réponses: 7
    Dernier message: 29/05/2006, 21h32

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