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

Shell et commandes GNU Discussion :

Problème CASE shell


Sujet :

Shell et commandes GNU

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2014
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre (Centre)

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

    Informations forums :
    Inscription : Juillet 2014
    Messages : 43
    Points : 31
    Points
    31
    Par défaut Problème CASE shell
    bonjour à tous,

    je débute en shell et j'ai un soucis lorsque j'execute ce script, il me retourne : newline or ; unexpected.
    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
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    	# Fichiers
    	test_vide=`ls $import | wc -l`
    	if [ $test_vide -ne 0 ] 
    	then
    	fichier_actuel=`basename $fich`;
     
    	case $fichier_actuel in 
        $import/*.ctl) 
           sqlplus -s apps/$password <<FIN
    		SET SERVEROUTPUT ON
    		BEGIN
    		XX_OCERP_PKG.add_source('$fichier_actuel','CTL','$import');
    		END;
    		/
    FIN
            ;; 
        $import/*.txt) 
            sqlplus -s apps/$password <<FIN
    		SET SERVEROUTPUT ON
    		BEGIN
    		XX_OCERP_PKG.add_source('$fichier_actuel','FORMS','$import'); 
    		END;
    		/
    FIN
    		;;
    	$import/*.sql) 
            sqlplus -s apps/$password <<FIN
    		SET SERVEROUTPUT ON
    		BEGIN
    		XX_OCERP_PKG.add_source('$fichier_actuel','SQL','$import'); 
    		END;
    		/
    FIN
    	$import/*.rex) 
            sqlplus -s apps/$password <<FIN
    		SET SERVEROUTPUT ON
    		BEGIN
    		XX_OCERP_PKG.add_source('$fichier_actuel','REPORTS','$import'); 
    		END;
    		/
    FIN
    		;;
    	$import/*.pld) 
            sqlplus -s apps/$password <<FIN
    		SET SERVEROUTPUT ON
    		BEGIN
    		XX_OCERP_PKG.add_source('$fichier_actuel','PLD','$import'); 
    		END;
    		/
    FIN
     
            ;;] 
     
    esac
    merci de votre aide

  2. #2
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 552
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 552
    Points : 19 392
    Points
    19 392
    Par défaut
    Bonjour,

    • il y a un crochet fermant en trop avent le escca.
    • le mot terminant un document en ligne doit être sur la première colonne du fichier.
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2014
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre (Centre)

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

    Informations forums :
    Inscription : Juillet 2014
    Messages : 43
    Points : 31
    Points
    31
    Par défaut
    merci mais le problème est toujours le même.


    Citation Envoyé par N_BaH Voir le message
    Bonjour,

    • le mot terminant un document en ligne doit être sur la première colonne du fichier.

    c'est à dire ?

  4. #4
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 552
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 552
    Points : 19 392
    Points
    19 392
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    cat <<eot
         bla
         bla
    eot
    ^--- première colonne
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2014
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre (Centre)

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

    Informations forums :
    Inscription : Juillet 2014
    Messages : 43
    Points : 31
    Points
    31
    Par défaut
    toujours pareil

  6. #6
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 101
    Points : 5 849
    Points
    5 849
    Par défaut
    Citation Envoyé par N_BaH Voir le message
    Bonjour,

    • il y a un crochet fermant en trop avent le escca.
    • le mot terminant un document en ligne doit être sur la première colonne du fichier.
    De plus, je crois qu'il manque un "fi" pour fermer le "if".

  7. #7
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 287
    Points : 12 744
    Points
    12 744
    Par défaut
    Bonjour,

    Il manque ';;' entre 2 condition du case (ligne 34 du post).
    Cordialement.

  8. #8
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2014
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre (Centre)

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

    Informations forums :
    Inscription : Juillet 2014
    Messages : 43
    Points : 31
    Points
    31
    Par défaut
    effectivement. merci.

    mais j'ai toujours l'erreur 'newline or ; unexpected' ligne 54

    la ligne 54 est celle de ' $import/*.ctl) ' (ligne 8 ici)

  9. #9
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 802
    Points
    30 802
    Par défaut
    Il manque aussi un ;; avant le cas $import/*.rex)
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  10. #10
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2014
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre (Centre)

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

    Informations forums :
    Inscription : Juillet 2014
    Messages : 43
    Points : 31
    Points
    31
    Par défaut
    merci mais aucun changement, toujours la même erreur

  11. #11
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 101
    Points : 5 849
    Points
    5 849
    Par défaut
    Sémantiquement parlant, il est pour le moins très surprenant de mettre le basename de $fich dans fich_actuel puis de comparer ce basename avec $import/*.ctl


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    	fichier_actuel=`basename $fich`;
     
    	case $fichier_actuel in 
        $import/*.ctl)
    Apparemment, seule l'extension compte. Donc plutôt:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    	fichier_actuel=`basename $fich`;
            ext=${fichier_actuel##*.}
     
    	case "$ext" in 
        ctl)
    etc.

    Peux-tu renvoyer la version courante du script et les erreurs?

  12. #12
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2014
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre (Centre)

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

    Informations forums :
    Inscription : Juillet 2014
    Messages : 43
    Points : 31
    Points
    31
    Par défaut
    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
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    # Fichiers
    test_vide=`ls $import | wc -l`
    if [ $test_vide -ne 0 ] 
    then
    fichier_actuel=`basename $fich`;
    ext=${fichier_actuel##*.}
     
    	case "$ext" in  
        ctl) 
    		   sqlplus -s apps/$password <<FIN
    			SET SERVEROUTPUT ON
    			BEGIN
    			XX_OCERP_PKG.add_source('$fichier_actuel','CTL','$import');
    			END;
    			/
    FIN
            ;; 
        txt) 
            sqlplus -s apps/$password <<FIN
    			SET SERVEROUTPUT ON
    			BEGIN
    			XX_OCERP_PKG.add_source('$fichier_actuel','FORMS','$import'); 
    			END;
    			/
    FIN
    		;;
    	sql) 
            sqlplus -s apps/$password <<FIN
    			SET SERVEROUTPUT ON
    			BEGIN
    			XX_OCERP_PKG.add_source('$fichier_actuel','SQL','$import'); 
    			END;
    			/
    FIN
    		;;
    	rex) 
            sqlplus -s apps/$password <<FIN
    			SET SERVEROUTPUT ON
    			BEGIN
    			XX_OCERP_PKG.add_source('$fichier_actuel','REPORTS','$import'); 
    			END;
    			/
    FIN
    		;;
    	pld) 
            sqlplus -s apps/$password <<FIN
    			SET SERVEROUTPUT ON
    			BEGIN
    			XX_OCERP_PKG.add_source('$fichier_actuel','PLD','$import'); 
    			END;
    			/
    FIN
    		;; 
    esac
    fi
    et toujours la même erreur ==> IMPORT3.sh: syntax error at line 55: `newline or ;' unexpected
    la ligne 55 correspondans au "ctl)"

  13. #13
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 287
    Points : 12 744
    Points
    12 744
    Par défaut
    Je ne pense pas que le problème vient de cette portion de code, cela peut venir de plus haut, comme par exemple un oublie de fermeture de guillemet (") ou de quote (')...
    Cordialement.

  14. #14
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 802
    Points
    30 802
    Par défaut
    Face à ce type de problème de syntaxe, on gagne du temps en passsant par l'option "débogage" c'est à dire en activant le mode verbeux (-v) et l'expansion des variables (-x) dans le shell.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  15. #15
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2014
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre (Centre)

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

    Informations forums :
    Inscription : Juillet 2014
    Messages : 43
    Points : 31
    Points
    31
    Par défaut
    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
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    # Test du nombre de paramètres
    echo "Debut de script"
    NB_PAR=`echo $* | wc -w`
    if [ $NB_PAR -eq 1 ] 
    then
    	echo "Il y a le bon nombre de paramètre" $NB_PAR
     
    fi
     
    # Variables globales
    password=it15ci
    import=$1
    if [ ! -d $import ]
      then
      echo "Répertoire $import inaccessible ou inexistant"
      exit 1
    fi
     
    # Import des sources dans la table XX_SOURCE
     
    	# Vidage de la table XX_SOURCE au préalable (pour éviter les doublons)
    	sqlplus -s apps/$password <<FIN
    	SET SERVEROUTPUT ON
    	BEGIN
    	XX_OCERP_PKG.vidage(3);
    	END;
    	/
    FIN
     
    # Fichiers
    test_vide=`ls $import | wc -l`
    if [ $test_vide -ne 0 ] 
    then
    fichier_actuel=`basename $fich`;
    ext=${fichier_actuel##*.}
     
    	case "$ext" in  
        ctl) 
    		   sqlplus -s apps/$password <<FIN
    			SET SERVEROUTPUT ON
    			BEGIN
    			XX_OCERP_PKG.add_source('$fichier_actuel','CTL','$import');
    			END;
    			/
    FIN
            ;; 
        txt) 
            sqlplus -s apps/$password <<FIN
    			SET SERVEROUTPUT ON
    			BEGIN
    			XX_OCERP_PKG.add_source('$fichier_actuel','FORMS','$import'); 
    			END;
    			/
    FIN
    		;;
    	sql) 
            sqlplus -s apps/$password <<FIN
    			SET SERVEROUTPUT ON
    			BEGIN
    			XX_OCERP_PKG.add_source('$fichier_actuel','SQL','$import'); 
    			END;
    			/
    FIN
    		;;
    	rex) 
            sqlplus -s apps/$password <<FIN
    			SET SERVEROUTPUT ON
    			BEGIN
    			XX_OCERP_PKG.add_source('$fichier_actuel','REPORTS','$import'); 
    			END;
    			/
    FIN
    		;;
    	pld) 
            sqlplus -s apps/$password <<FIN
    			SET SERVEROUTPUT ON
    			BEGIN
    			XX_OCERP_PKG.add_source('$fichier_actuel','PLD','$import'); 
    			END;
    			/
    FIN
    		;; 
    esac
    fi
    le script complet

  16. #16
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 101
    Points : 5 849
    Points
    5 849
    Par défaut
    Autre piste possible (désespérée!): ton fichier vient-il du monde Windows?

    que donne od -c <le_script> | head ?

    et que donne od -c <le_script> | tail (pour vérifier le newline final)?


    (car le script marche "très bien" chez moi:

    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
    $ ./foo.sh
    Debut de script
    ERROR:
    ORA-12560: TNS : erreur d'adaptateur de protocole
     
     
    SP2-0306: Option non valide.
    Syntaxe : CONN[ECT] [logon] [AS {SYSDBA|SYSOPER|SYSASM}]
    o▒ <logon>  ::= <username>[/<password>][@<connect_identifier>] [edition=value] | /
    ERROR:
    ORA-12560: TNS : erreur d'adaptateur de protocole
     
     
    SP2-0157: impossible de se CONNECTER ▒ ORACLE apr▒s 3 essais, sortie de SQL*Plus
    basename: opérande manquant
    Saisissez «*basename --help*» pour plus d'informations.
    )

    Petite remarque: $# donne le nombre d'arguments de manière plus fiable que NB_PAR=`echo $* | wc -w` !

Discussions similaires

  1. problème commande shell compilation auto
    Par ludovic85 dans le forum C#
    Réponses: 1
    Dernier message: 07/02/2007, 12h28
  2. Problème commandes shell-trop d'arguments
    Par SuperCed dans le forum Shell et commandes GNU
    Réponses: 3
    Dernier message: 22/12/2006, 12h57
  3. Problème avec SHELL
    Par Jasgui dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 19/09/2006, 19h14
  4. Problème cases à cocher avec connection Mysql
    Par cams dans le forum SQL Procédural
    Réponses: 8
    Dernier message: 01/12/2005, 14h13
  5. []Problème de SHELL
    Par laurentfrancis dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 08/10/2005, 19h41

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