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++Builder Discussion :

[OLE] Ouvrir un fichier Excel


Sujet :

C++Builder

  1. #1
    Membre du Club
    Inscrit en
    Octobre 2004
    Messages
    115
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 115
    Points : 68
    Points
    68
    Par défaut [OLE] Ouvrir un fichier Excel
    Bonjour à tous,

    j'ai besoin d'un petit coup de main pour ouvrir un fichier excel.
    Suis à la mise à jour d'Office vers la dernière version (Office 2016) ou la mise à jour de la version de Rad Studio, mon code ne fonctionne plus.

    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
      // Creation de l'instance d'excel
      //---------------------------------------------------------------------------
      Variant  vMSExcel, vXLWorkbooks vXLWorkbook;
      try
      {vMSExcel = Variant::GetActiveObject("Excel.Application");}
      catch(...)
      {vMSExcel = Variant::CreateObject("Excel.Application");}
     
      vMSExcel.OlePropertySet("Visible", false);
      //---------------------------------------------------------------------------
     
      // Ouverture du fichier
      //---------------------------------------------------------------------------
      vXLWorkbooks = FormPrincipale->vMSExcel.OlePropertyGet("Workbooks");
      vXLWorkbook = FormPrincipale->vXLWorkbooks.OleFunction("Open","c:\\NomFichierExcel.xls");
      //---------------------------------------------------------------------------
    J'avais récupéré ce code dans la FAQ et fonctionnait très bien, mais la dernière ligne ne fonctionne plus et fait planter le programme avec un message d'erreur aléatoire :
    Soit j'ai un message du type "Désolé... Nous ne trouvons pas (Nom du fichier excel tronqué).xls. Peut-être l'avez vous déplacé, renommé ou supprimé
    ou "La méthode Open de la classe Workbooks à echoué"

    Quelqu'un aurait une idée ?

    Merci d'avance

  2. #2
    Membre du Club
    Inscrit en
    Octobre 2004
    Messages
    115
    Détails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 115
    Points : 68
    Points
    68
    Par défaut
    J'ai trouvé une solution. Il faut mettre (OleVariant) à certains endroit :

    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
     
    OleVariant vNomFichier;
    Variant vMSExcel;
    Variant vXLWorkbooks, vXLWorkbook, vWorksheet, vXLTitreOnglet;
    Variant vUsedRange;
     
      // Creation de l'instance d'excel
      //---------------------------------------------------------------------------
      try
      {vMSExcel = Variant::GetActiveObject("Excel.Application");}
      catch(...)
      {vMSExcel = Variant::CreateObject("Excel.Application");}
     
      //Application excel masquée
      vMSExcel.OlePropertySet("Visible", false);
      //---------------------------------------------------------------------------
     
      // Ouverture du fichier
      //---------------------------------------------------------------------------
      vXLWorkbooks = vMSExcel.OlePropertyGet("Workbooks");
      vXLWorkbook = vXLWorkbooks.OleFunction("Open",vNomFichier);
      //---------------------------------------------------------------------------
     
     
      //Pour lire une cellule d'un classeur particulier
      Variant vWorksheet = vMSExcel.OlePropertyGet("Sheets", (OleVariant)"NomFeuille");
      Variant vCell = vWorksheet.OlePropertyGet("Range", (OleVariant)"E33");
      String asValeur = vCell.OlePropertyGet("Value");
     
     
      //Fermer le fichier sans sauvegarder
      Variant vSaveChanges = false;
      vXLWorkbook.OleFunction("Close", vSaveChanges);
      vMSExcel.OleFunction("Quit");
    Il y a peut-être plus simple mais pour l'instant ce code fonctionne.

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

Discussions similaires

  1. [VB]ouvrir un fichier excel
    Par elasfer dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 15/10/2005, 09h31
  2. ouvrir un fichier excel coté client
    Par youss dans le forum Servlets/JSP
    Réponses: 12
    Dernier message: 27/07/2005, 14h42
  3. comment ouvrir un fichier excel ?
    Par vdavid1982 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 13/07/2005, 12h05
  4. ouvrir un fichier Excel avec une requete perso
    Par legillou dans le forum Access
    Réponses: 9
    Dernier message: 21/06/2005, 15h14
  5. Ouvrir un fichier excel depuis access
    Par ptitegrenouille dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 03/05/2005, 11h47

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