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 :

Ouvrir un fichier apres SaveFileDialog


Sujet :

C#

  1. #1
    Membre habitué
    Inscrit en
    Août 2008
    Messages
    1 596
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 1 596
    Points : 175
    Points
    175
    Par défaut Ouvrir un fichier apres SaveFileDialog
    Bonjour, j'ai crée un fichier et je veux l'ouvrir une fois enregistré, comment puis je faire ?
    Merci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SaveFileDialog saveDialog = new SaveFileDialog();
                    saveDialog.Filter = "Excel Files (*.xlsx)|*.xlsx|All files (*.*)|*.*";
                    saveDialog.FilterIndex = 2;
     
                    workbook.SaveAs(@"C:\ModelesRapports\" + worksheet.Name);

  2. #2
    Membre confirmé Avatar de joKED
    Profil pro
    Imposteur en chef
    Inscrit en
    Février 2006
    Messages
    337
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Imposteur en chef

    Informations forums :
    Inscription : Février 2006
    Messages : 337
    Points : 458
    Points
    458
    Par défaut
    Salut,

    Vu que tu enregistre un fichier Excel via l'objet Workbook, pourquoi ne pas l'ouvrir via le même objet (workbook.open) ?
    Tant va la cruche à l'eau qu'à la fin y'a plus d'eau.

  3. #3
    Membre confirmé
    Avatar de nouanda
    Homme Profil pro
    Hobbyist
    Inscrit en
    Mai 2002
    Messages
    246
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Australie

    Informations professionnelles :
    Activité : Hobbyist

    Informations forums :
    Inscription : Mai 2002
    Messages : 246
    Points : 627
    Points
    627
    Par défaut
    Bonjour,

    Tel quel, ton SaveFileDialog ne sert a rien, puisque tu n'utilises pas le resultat du dialogue.

    Il te faudrait quelque chose comme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
      if (saveFileDialog1.ShowDialog() == DialogResult.OK)
      {
          workbook.SaveAs(saveFileDialog1.OpenFile());
      }
    une fois cela fait, tu peux vérifier que le fichier existe bien, avec File.Exists(chemin_du_fichier) (qui nécessite using System.IO; bien sur), et l'ouvrir avec l'application par défaut en utilisant System.Diagnostics.Process.Start(chemin_du_fichier).
    " Entre le Savoir et le Pouvoir, il y a le Vouloir "

    Desole pour les accents, je suis en QWERTY...

  4. #4
    Membre habitué
    Inscrit en
    Août 2008
    Messages
    1 596
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 1 596
    Points : 175
    Points
    175
    Par défaut
    cela ne marche pas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     if (saveFileDialog1.ShowDialog() == DialogResult.OK)
      {
          workbook.SaveAs(saveFileDialog1.OpenFile());
      }
    malgré que le fichier existe

  5. #5
    Membre habitué
    Inscrit en
    Août 2008
    Messages
    1 596
    Détails du profil
    Informations forums :
    Inscription : Août 2008
    Messages : 1 596
    Points : 175
    Points
    175
    Par défaut
    j'ai essayé de lire le fichier comme suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    StreamReader sr = new StreamReader(path)

    mais il me dit que c'est impossible d'accéder au fichier, une idée svp ?

  6. #6
    Membre expérimenté

    Homme Profil pro
    Responsable des études
    Inscrit en
    Mars 2009
    Messages
    553
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2009
    Messages : 553
    Points : 1 672
    Points
    1 672
    Par défaut
    Citation Envoyé par Msysteme Voir le message
    cela ne marche pas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     if (saveFileDialog1.ShowDialog() == DialogResult.OK)
      {
          workbook.SaveAs(saveFileDialog1.OpenFile());
      }
    malgré que le fichier existe
    Bonjour,

    As-tu fait un peu de recherche sur les méthodes que tu utilises ?
    Workbook.SaveAs() attend un objet de type 'string' qui définit le chemin du fichier dans lequel faire la sauvegarde.
    Mais SaveFileDialog.OpenFile() te retourne un objet de type 'Stream'.
    Ca ne peut donc pas fonctionner.

    Essaye plutôt de faire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    if (saveFileDialog1.ShowDialog() == DialogResult.OK)
    {
          workbook.SaveAs(saveFileDialog1.FileName);
    }

  7. #7
    Expert confirmé
    Avatar de popo
    Homme Profil pro
    Analyste programmeur Delphi / C#
    Inscrit en
    Mars 2005
    Messages
    2 654
    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 654
    Points : 5 209
    Points
    5 209
    Par défaut
    C'est surtout que OpenFile() récupère le contenu du fichier sélectionné (d'où le Stream).
    Dans ton cas, cela ne sert strictement à rien puisque c'est le workbook qui enregistre le fichier et que pour ça, il lui faut surtout le chemin.

    Je rejoint nnovic dans la solution, en précisant :
    1) Que j'adore cette auteur (s'il est bien tiré de Naomi Novik, donc avec un k ou lieu du c)
    2) Qu'il est préférable de prendre l'habitude d'utiliser la forme "using" sur les objets implémentant IDisposable

    Je sais que le point 1 est totalement hors de propos.

    Illustration du point 2 :
    Code C# : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    using (SaveFileDialog dialog = new SaveFileDialog())
    {
        dialog.Filter = "Excel Files (*.xlsx)|*.xlsx|All files (*.*)|*.*";
        dialog.FilterIndex = 2;
        if (dialog.ShowDialog() == DialogResult.OK)
        {
            workbook.SaveAs(dialog.FileName);
        }
    }

Discussions similaires

  1. Réponses: 0
    Dernier message: 16/01/2012, 16h29
  2. [XL-2003] ouvrir fichier après impression pdfcreator
    Par Sécateur dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 30/07/2011, 18h31
  3. [WD15] Ouvrir un fichier après sélection
    Par anelinette dans le forum WinDev
    Réponses: 1
    Dernier message: 28/09/2010, 17h34
  4. Ouvrir un fichier PDF après l'avoir créé avec PDFCreator ?
    Par OtObOx dans le forum Général VBA
    Réponses: 2
    Dernier message: 15/03/2008, 22h13
  5. Ouvrir fichier apres recherche multicriteres
    Par pezihale_84 dans le forum Access
    Réponses: 1
    Dernier message: 29/06/2006, 11h05

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