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

Windows Forms Discussion :

SaveFileDialog pour un fichier excel


Sujet :

Windows Forms

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Février 2008
    Messages
    354
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Tunisie

    Informations forums :
    Inscription : Février 2008
    Messages : 354
    Points : 139
    Points
    139
    Par défaut SaveFileDialog pour un fichier excel
    Bonjour,
    J'ai besoin de créer un fichier excel en utilisant la boite de dialogue SaveFileDialog.
    Donc j'ai écrit les lignes suivantes
    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
     
    Stream^ myStream;
    DateTime date;
    System::String ^pathFile="";
    SaveFileDialog^ saveFileDialog1 = gcnew SaveFileDialog;
    saveFileDialog1->Filter = "Fichier Excel (*.xls)|*.xls|(*.xlsx)|*.xlsx|All   files (*.*)|*.*";
    saveFileDialog1->FilterIndex = 2;
    saveFileDialog1->CreatePrompt=true;
    String^ str=date.Now.Year.ToString()+"-"+date.Now.Month.ToString()+"-"+date.Now.Day.ToString();
    saveFileDialog1->FileName=str;
    saveFileDialog1->InitialDirectory="C:\\Files";
    saveFileDialog1->RestoreDirectory = true;
    try
    {
        if ( saveFileDialog1->ShowDialog() == ::DialogResult::OK )
        {
    	if ( (myStream = saveFileDialog1->OpenFile()) != nullptr )
            {
    		pathFile=saveFileDialog1->FileName;
            	//ouvrir excel
    	       // Code to write the stream goes here.
                  myStream->Close();
             }
         }
     
    }
    catch(Exception ^ex)
    {
    	MessageBox::Show(ex->Message);
    }
    Le problème est que lorsque j'ai essayé d'ouvrir le fichier le message suivant m'apparait
    Impossible d'ouvrir le fichier "2011-3-18" car son format ou son extension n'est pas valide. vérifier que le fichier n'est pas endommagé et que son extension correspond bien au format du fichier
    Puis j'ai essayé d'ajouter les lignes suivantes:
    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
     
    if ( (myStream = saveFileDialog1->OpenFile()) != nullptr )
    {
         pathFile=saveFileDialog1->FileName;
         //ouvrir excel
         myApplication = gcnew Microsoft::Office::Interop::Excel::ApplicationClass ();
         myApplication->Workbooks->Add(Type::Missing);
         myApplication->ActiveWorkbook->SaveCopyAs(pathFile);
         myApplication->ActiveWorkbook->Saved = true;
         // Code to write the stream goes here.
         myStream->Close();
    }
     
     
    releaseObject(myWorkbook);
    myApplication->Quit();
    mais je trouve le même problème.
    Merci.

  2. #2
    Membre confirmé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Juin 2005
    Messages
    700
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Tourisme - Loisirs

    Informations forums :
    Inscription : Juin 2005
    Messages : 700
    Points : 488
    Points
    488
    Par défaut
    Tu devrai peut etre t'assurer que le fichier existe bien...
    SaveFileDialogue à une propriété qui permet de griser OK si le fichier n'existe pas.

    Es tu sur que ton fichier n'est pas corrompu?

  3. #3
    Rédacteur
    Avatar de Nathanael Marchand
    Homme Profil pro
    Expert .Net So@t
    Inscrit en
    Octobre 2008
    Messages
    3 615
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Expert .Net So@t
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2008
    Messages : 3 615
    Points : 8 080
    Points
    8 080
    Par défaut
    et en ajoutant ".xls" a ton str ?

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Février 2008
    Messages
    354
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Tunisie

    Informations forums :
    Inscription : Février 2008
    Messages : 354
    Points : 139
    Points
    139
    Par défaut
    Bonjour
    @Nathanael Marchand: c'est pas nécessaire d'ajouter .xls au fichier car ça s'ajoute automatiquement par la boite de dialogue saveDialog
    @giova_fr: la boite de dialogue fait la vérification toute seule. EN faite si ce fichier existe déjà alors il demeande si vous voukez l'enregistrer ou non.

  5. #5
    Rédacteur/Modérateur
    Avatar de Skalp
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2006
    Messages
    1 694
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 694
    Points : 2 927
    Points
    2 927
    Par défaut
    Citation Envoyé par moooona Voir le message
    @Nathanael Marchand: c'est pas nécessaire d'ajouter .xls au fichier car ça s'ajoute automatiquement par la boite de dialogue saveDialog.
    As-tu tout de même essayé ?

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Février 2008
    Messages
    354
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : Tunisie

    Informations forums :
    Inscription : Février 2008
    Messages : 354
    Points : 139
    Points
    139
    Par défaut
    oui,
    j'ai essayé mais ça n'a pas marché

  7. #7
    Rédacteur/Modérateur
    Avatar de Skalp
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2006
    Messages
    1 694
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 694
    Points : 2 927
    Points
    2 927
    Par défaut
    Ton code fonctionne chez moi (en C#).

    Essaye de créer un nouveau contrôle SaveFileDialog en laissant tous les paramètres par défaut et teste-le.

Discussions similaires

  1. Réponses: 13
    Dernier message: 06/03/2017, 09h47
  2. Macro unique pour plusieurs fichiers excel
    Par jackbauer972 dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 09/07/2007, 13h41
  3. SaveFileDialog pour un fichier dans un programme
    Par jockyboss777 dans le forum VB.NET
    Réponses: 67
    Dernier message: 09/06/2007, 18h43
  4. [VBA-E] Macro pour tous fichiers Excel ?
    Par belfaigore dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 05/07/2006, 18h25
  5. [VBA-E]une macro unique pour plusieurs fichiers excel
    Par fanchic29 dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/04/2006, 16h20

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