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

Linux Discussion :

erreur en bash


Sujet :

Linux

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 16
    Par défaut erreur en bash
    Bonjour,
    J'ai un script a écrire pour un travail de session. J'obtiens l'erreur suivante quand j'execute le script:

    line 6: syntax error near unexpected token `do

    Voici le code:

    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
    #!/bin/sh
     
    while [ -n $1 ]
     
    do
     
    list= ls $1
     
    for i in $list
     
    do
     
    cat $i >> basename $i
     
    rm $i
     
    done
     
    shift 1
     
    done
    Je suis certain que c'est une erreur de syntaxe mais j'arrive pas a trouver.

    Merci

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 664
    Par défaut
    Ah, oui, mais là, non !

    Allez, je vais pas être plus méchant, prend le temps de lire ce tutoriel.
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 840
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par trealais Voir le message
    Je suis certain que c'est une erreur de syntaxe mais j'arrive pas a trouver.Merci
    Comment veux-tu que le shell fasse la différence entre
    et
    ???

    Accessoirement, tu peux remplacer
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    while [ -n $1 ]
    do
     .... $1
    shift
    done

    par
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    for file in $*
    do
     .... $file
    done
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 16
    Par défaut
    Je viens de commencer a programmer en shell. En fait ca fait 1 semaine.
    Faut me laisser une chance...

    Citation Envoyé par Sve@r Voir le message
    Comment veux-tu que le shell fasse la différence entre
    et
    ???

    Comment écrirais-tu list=ls $1 alors?
    Je cherches encore une solution

    Merci

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 16
    Par défaut
    J'obtiens toujours l'erreur même si j'écris avec des apostrophes.

    comme suit:

  6. #6
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 840
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par trealais Voir le message
    Je viens de commencer a programmer en shell. En fait ca fait 1 semaine.
    Faut me laisser une chance...
    ok

    Citation Envoyé par trealais Voir le message
    J'obtiens toujours l'erreur même si j'écris avec des apostrophes.

    comme suit:
    list='ls $1'
    Ce que tu cherches à faire est le mécanisme le plus important du shell et ce qui fait sa force. Ca permet au shell de déléguer à d'autres programmes (comme "ls") ce qu'il ne sait pas faire lui-même (comme lister le contenu du répertoire).

    Il faut encadrer la commande d'accent graves (ou backquottes). A ce moment là, le shell exécute la commande mais récupère pour son propre usage le texte qui aura été affiché. Et donc ici, ce texte sera stocké dans la variable "list"

    Dans les shells récents, on peut remplacer les backquottes par $(...) plus lisible

    Ainsi, quel que soit ton besoin, t'auras toujours un programme qui te donnera ce que t'attends (au pire tu l'écris toi-même en C ou autre) puis tu demandes au shell d'exécuter ledit programme et grâce à ce mécanisme, tu récupères dans ton script le résultat dudit programme. Bref tu fais tout faire par ce qui existe au lieu de le réinventer à chaque fois.

    S'il y a une seule chose que tu dois apprendre à faire en shell et que tu dois étudier hyper attentivement, c'est ça parce que grâce à ça, tous tes besoins en programmation shell sont à 90% déjà résolus. T'as simplement qu'à appeler le bon programme à chaque fois que t'as un truc à faire.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 16
    Par défaut
    Dans les shells récents, on peut remplacer les backquottes par $(...) plus lisible

    Merci pour les infos.
    C'est bizzare j'obtiens toujours la même erreur et même ce après avoir remplacé:
    par
    Le problème semble être avec:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    for i in $list
     
    do
    Merci

  8. #8
    Membre éprouvé
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 133
    Par défaut
    Il y a un problème avec le while que j'arrive à isoler mais je ne sais pas d'où cela vient, ça fait trop longtemps que je n'ai pas fait de bash pour ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    #!/bin/bash
    while [ -n $1 ]
    do
    if [[ -n $1 ]]
    then
    	echo X$1X not null ;
    else
    	echo X$1X null ;
    fi
    shift 1
    done
    Il rentre dans le while alors que $1 est vide...

    en utilisant for file comme indiqué ça fonctionne mais cela m'intrigue quand même.

  9. #9
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 840
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Zartan Voir le message
    Il y a un problème avec le while que j'arrive à isoler mais je ne sais pas d'où cela vient, ça fait trop longtemps que je n'ai pas fait de bash pour ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    #!/bin/bash
    while [ -n $1 ]
    do
    if [[ -n $1 ]]
    then
    	echo X$1X not null ;
    else
    	echo X$1X null ;
    fi
    shift 1
    done
    Il rentre dans le while alors que $1 est vide...

    en utilisant for file comme indiqué ça fonctionne mais cela m'intrigue quand même.
    Remplace while [ -n $1 ] par while [ -n "$1" ] et t'auras plus ce soucis.


    Citation Envoyé par trealais Voir le message
    Dans les shells récents, on peut remplacer les backquottes par $(...) plus lisible

    Merci pour les infos.
    C'est bizzare j'obtiens toujours la même erreur et même ce après avoir remplacé:
    list=`ls $1`
    par
    list=$(ls $1)

    Le problème semble être avec:
    for i in $list

    do

    Merci
    Le meilleur débugging c'est le "echo". Rajoute un echo "[$list]" juste avant le for histoire de voir avec exactitude ce que contient ta variable...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  10. #10
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 16
    Par défaut
    Merci pour votre aide.
    J'obtiens toujours l'erreur même avec: while [ -n "$1" ]
    Je me demande maintenant comment implanter le: for file in $*

    Est-ce comme ceci?:

    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
    #!/bin/sh
     
    for file in $*
     
    do
     
    for i in $file
    do
     
    cat $i >> `basename $i`
     
    rm $i
     
    done
     
    shift 1
     
    done
    Si c'est le cas j'obtiens toujours la même erreur.
    Il y a un mec sur un autre forum qui dit que mon code semble fonctionner sur Mac OS X.
    Bizarre...

    Merci pour votre aide.

  11. #11
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 840
    Billets dans le blog
    1
    Par défaut
    Ok, avant de continuer, j'aimerais être sûr de ce que tu veux faire. Il me semble en lisant ton script que tu cherches à lister le contenu de répertoires et à recopier les fichiers desdits répertoires dans ton dossier courant.

    Si c'est ça, alors ton script a une erreur dans le "for i in $file". Il te faut mettre à la place "for i in $file/*" afin d'avoir le contenu de "$file" et non son simple nom.

    Accessoirement le shift 1 devient inutile. De plus, il peut être judicieux de choisir ses noms de variable en rapport avec leur rôle. $file semble être destiné à recevoir un nom de dossier donc autant l'appeler "$dir".

    De plus, l'erreur de ton premier script devient claire. Quand tu fais "list=`ls $1`", la variable "list" ne contient que les noms des fichiers situés dans "$1" et non leur chemin d'accès. Exemple: si t'as un répertoire "aaa" qui contient "toto", ta variable "list" contiendra "toto" et non "aaa/toto".
    Il s'ensuit que pour que ton premier script fonctionne, il suffisait de remplacer
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    cat $i >> basename $i
    rm $i
    par
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    cat $1/$i >> $i
    rm $1/$i

    A titre d'exemple, voici ton premier script que j'ai corrigé dans le but de le faire correspondre à ce que je crois que tu cherches à faire

    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    #!/bin/sh
    while test -n "$1"
    do
        test ! -d "$1" && shift 1 && continue
     
        for file in `ls "$1"`
        do
            cat "$1/$file" >> "$file"
            rm "$1/$file"
       done
    shift 1
    done

    Et le même avec un for à la place d'un while

    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    #!/bin/sh
    for dir in $*
    do
        test ! -d "$dir" && continue
     
        for file in $dir/*
        do
            cat "$file" >> `basename "$file"`
            rm "$file"
       done
    done

    Tu remarqueras qu'il y a une différence notable entre "ls <nom_de_dossier>" et "<nom_de_dossier>/*"
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  12. #12
    Rédacteur/Modérateur
    Avatar de troumad
    Homme Profil pro
    Enseignant
    Inscrit en
    Novembre 2003
    Messages
    5 607
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 5 607
    Par défaut
    trealais, il serait important que tu dises exactement ce que doit faire ton programme ! Et ce dès le début, ça éviterait de se poser trop de questions et ça permettrait de trouver plus rapidement la réponse...
    Ainsi que les retours demandés par Sve@r, il serait bien de les donner ! Ce qu'il dit me semble cohérent bien que je ne sois pas un expert shell.
    Modérateur Mageia/Mandriva Linux
    Amicalement VOOotre
    Troumad Alias Bernard SIAUD à découvrir sur http://troumad.org
    Mes tutoriels : xrandr, algorigramme et C, xml et gtk...

  13. #13
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    16
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 16
    Par défaut
    Citation Envoyé par troumad Voir le message
    trealais, il serait important que tu dises exactement ce que doit faire ton programme ! Et ce dès le début, ça éviterait de se poser trop de questions et ça permettrait de trouver plus rapidement la réponse...
    Ainsi que les retours demandés par Sve@r, il serait bien de les donner ! Ce qu'il dit me semble cohérent bien que je ne sois pas un expert shell.
    Pas de problèmes voici l'énoncé de la question à laquelle je dois répondre:

    Faire un script en Shell avec un nombre variable de paramètres qui sont des
    directories existants dans le directory courant. Pour chacun des directories nommés, le script doit déplacer tous ses fichiers au directory courant. Si les noms des fichiers les mêmes, le script doit concaténer les fichiers sous un même nom dans le directory courant.


    Merci pour votre aide!

  14. #14
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 840
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par trealais Voir le message
    Pas de problèmes voici l'énoncé de la question à laquelle je dois répondre:

    Faire un script en Shell avec un nombre variable de paramètres qui sont des
    directories existants dans le directory courant. Pour chacun des directories nommés, le script doit déplacer tous ses fichiers au directory courant. Si les noms des fichiers les mêmes, le script doit concaténer les fichiers sous un même nom dans le directory courant, SAUF s'il s'agit d'un fichier
    de type PDF où le programme élimine simplement le fichier.

    Quand les directories nommés en paramètre sont vidés, ils doivent être détruits.

    N.B. On suppose que les directories nommés ne contiennent que des fichiers (pas de sous-directories), et que lorsque votre programme trouve un nom identique au directory courant, ce dernier est un fichier valide à concaténer.

    Merci pour votre aide!
    Ouais ok. Mes exemples correspondent quasiment à ce que tu dois faire. Faut juste rajouter la commande d'effacement du dossier devenu vide (rmdir) et le filtre du pdf => if echo $file |grep -y "\.pdf$" 1>/dev/null renverra vrai si ton nom de fichier porte l'extension ".pdf" en minuscules ou majuscules.

    Toutefois tu triches un peu car tu fais une concaténation systématique alors que ton énoncé suppose à un moment donné un examen du fichier trouvé pour voir s'il n'existe pas déjà. Ca marche mais si c'est un TP, alors peut-être que ton prof attend de toi que tu écrives ce test afin que tu lui montres que t'es bien à l'aise à la fois dans ta tête (ça ça semble ok) et à la fois dans ton shell (un peu d'expérience et ça viendra aussi).

    Appuies-toi sur mes scripts pour comprendre leur façon d'agir et sur mes remarques à propos de la façon dont tes variables sont remplies (le coup des chemins d'accès présents ou pas) et complète ton tp.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

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

Discussions similaires

  1. Erreur script bash
    Par leninelenine dans le forum Shell et commandes GNU
    Réponses: 6
    Dernier message: 06/02/2015, 11h08
  2. [FreeBSD] Erreur à la compilation de Bash
    Par Neuromancien2 dans le forum BSD
    Réponses: 2
    Dernier message: 27/12/2007, 15h00
  3. [bash][Débutant] Erreurs d'exécution avec read
    Par Alcatîz dans le forum Shell et commandes GNU
    Réponses: 6
    Dernier message: 14/09/2007, 15h28
  4. Réponses: 3
    Dernier message: 25/04/2007, 13h53
  5. récupération d'erreur dans le bash
    Par will972 dans le forum VBScript
    Réponses: 5
    Dernier message: 03/04/2007, 16h07

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