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

Vue hybride

Message pr�c�dent Message pr�c�dent   Message suivant Message suivant
  1. #1
    Membre confirm�
    Inscrit en
    Octobre 2004
    Messages
    115
    D�tails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 115
    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 confirm�
    Inscrit en
    Octobre 2004
    Messages
    115
    D�tails du profil
    Informations forums :
    Inscription : Octobre 2004
    Messages : 115
    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