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 :

problème avec l'opérateur || ( or )


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Décembre 2007
    Messages
    105
    Détails du profil
    Informations forums :
    Inscription : Décembre 2007
    Messages : 105
    Par défaut problème avec l'opérateur || ( or )
    Salut tout le monde
    J’ai un problème avec l’opérateur or (||)
    Dans mon application je récupère l’extesion d’un fichier et après je fais les test.
    Si il est diffrents de .pdf / .doc / .bat / .txt alors à ce moment un message d’erreur s’affiche, le problème c’est mêm si le fichier a une extension valide le message s’affiche :
    if ((ExtScanPath1 != ".pdf") ||((ExtScanPath1 != ".doc") ||((ExtScanPath1 != ".txt") )
    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
     
    /* Ouverture de OpenFileDialog*/
                OpenFileDialog OFD = new OpenFileDialog();
                OFD.ShowDialog();
     
                /* Récupération du chemin du fichier ainsi que son extension*/
                string scanPath1 = OFD.FileName.ToString();
                string ExtScanPath1=System.IO.Path.GetExtension(scanPath1).ToString(); 
     
                /* Test sur la validité de l'extension du fichier*/
                if ((ExtScanPath1 != ".pdf") ||((ExtScanPath1 != ".doc") )
                     {
                         System.Windows.Forms.MessageBox.Show("This File is invalid");   
                     }           
                else
                     {
                         /* Lancement du fichier pour visualisation */
                         Process.Start(scanPath1);
                         lblFileScan1.Text = scanPath1;
                         /* test de l'existence du fichier et upload */
                         if (System.IO.File.Exists(scanPath1))
                         {
                             System.IO.File.Copy(scanPath1,@"E:\Projets\RainaSolutions\Nouveau dossier\Courtney_v2p0p1\Courtney_v2p0p1\Files\" + "FileScan1Contract" + txtcontractID.Text + ".pdf");
                         }                    
                        lblDeleteFile1.Visible = true; 
                    }

  2. #2
    Rédacteur
    Avatar de Thomas Lebrun
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    9 161
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 9 161
    Par défaut
    Tu as essayé de faire afficher le contenu de ExtScanPath1 pour voir ce qu'il y a dedans ?

  3. #3
    Membre confirmé
    Inscrit en
    Décembre 2007
    Messages
    105
    Détails du profil
    Informations forums :
    Inscription : Décembre 2007
    Messages : 105
    Par défaut
    oui je l'a déjà fait afficher l'extension et elle est valide :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     System.Windows.Forms.MessageBox.Show("System.IO.Path.GetExtension(scanPath1).ToString()");
    j'obtient : .pdf

  4. #4
    Membre émérite
    Avatar de neilbgr
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2004
    Messages
    651
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Août 2004
    Messages : 651
    Par défaut
    Ton code ne me parait pas correcte, et ne compile pas.
    Il y a un pb de parenthèses.
    Enfin, les .ToString() sont inutiles.
    Code c# : 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
    /* Ouverture de OpenFileDialog*/
    			OpenFileDialog OFD = new OpenFileDialog();
    			OFD.ShowDialog();
     
    			/* Récupération du chemin du fichier ainsi que son extension*/
    			string scanPath1 = OFD.FileName;
    			string ExtScanPath1=System.IO.Path.GetExtension(scanPath1);
     
    			/* Test sur la validité de l'extension du fichier*/
    			if (ExtScanPath1 != ".pdf" || ExtScanPath1 != ".doc" )
    			{
    				System.Windows.Forms.MessageBox.Show("This File is invalid");
    			}
    			else
    			{
    				/* Lancement du fichier pour visualisation */
    				Process.Start(scanPath1);
    				lblFileScan1.Text = scanPath1;
    				/* test de l'existence du fichier et upload */
    				if (System.IO.File.Exists(scanPath1))
    				{
    					System.IO.File.Copy(scanPath1,@"E:\Projets\RainaSolutions\Nouveau dossier\Courtney_v2p0p1\Courtney_v2p0p1\Files\" + "FileScan1Contract" + txtcontractID.Text + ".pdf");
    				}
    				lblDeleteFile1.Visible = true;
    			}

  5. #5
    Membre éprouvé Avatar de Nikoui
    Inscrit en
    Décembre 2007
    Messages
    119
    Détails du profil
    Informations personnelles :
    Âge : 45

    Informations forums :
    Inscription : Décembre 2007
    Messages : 119
    Par défaut
    Ce n'est pas des "ou" qu'il faut mettre, mais des "et". Si ce n'est pas un pdf, ni un doc, ni un text alors erreur...

    Dans ton cas, si tu as un pdf, le "!= de doc" sera vrai donc tu rentre dans ta condition...

  6. #6
    Membre émérite
    Avatar de neilbgr
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Août 2004
    Messages
    651
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

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

    Informations forums :
    Inscription : Août 2004
    Messages : 651
    Par défaut
    Bon désolé, j'ai mal lu, mais c'est encore plus simple.
    Ce n'est pas un "ou" logique qu'il faut utiliser, mais un "et" logique...
    Pourquoi ? car tu utilises des test de différences "!=".
    Donc, SI (Extension est différent de ".pdf" ET Extension est différent de ".txt") ALORS c'est pas bon AUTREMENT c'est bon
    Ou bien: SI (Extension est égale à ".pdf" OU Extension est égale à ".txt") ALORS C'est bon AUTREMENT c'est pas bon

    vu ?

  7. #7
    Membre confirmé
    Inscrit en
    Décembre 2007
    Messages
    105
    Détails du profil
    Informations forums :
    Inscription : Décembre 2007
    Messages : 105
    Par défaut
    je vous remercie, et je vous félicite c'est exactement ce que je cherche

    ou lieu de || je dois mettre un &&.

    bravooooooooooo Nikoui

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 28/12/2008, 18h51
  2. Problème avec l'opérateur <<
    Par desde dans le forum C++
    Réponses: 2
    Dernier message: 15/03/2008, 12h04
  3. [VB6] Problème avec l'opérateur LIKE en SQL
    Par MGD_Software dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 22/07/2006, 14h56
  4. Réponses: 12
    Dernier message: 11/04/2006, 11h41
  5. Problème avec les opérateurs
    Par jules_lenoir dans le forum Langage
    Réponses: 4
    Dernier message: 26/01/2006, 16h56

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