|
|
|
|
Bonjour,
Encore un exercice coriace dont je n'arrive pas à me défaire (ca me démoralise), voila l'énnoncé :
Écrire un script shell enlever-des-lignes.sh qui prend en premier paramètre un nom de fichier puis une liste d’entier.
Ce script doit renvoyer sur la sortie standard le contenu du fichier passé en premier paramètre auquel on aura supprimé les lignes passée via les autres paramètres. Par exemple,
$ ./supprime-ligne fichier.txt 2 5 11 devra renvoyer le contenu du fichier fichier.txt supprimé des lignes 2, 5 et 11.
Votre script devra supporter n’importe quel ordre de passage des numéros de lignes. Par exemple,
$ ./supprime-ligne fichier.txt 11 2 5 aura le même effet.
Votre script devra également prendre en compte des intervalles de lignes via la notation ?numéro-début-ligne
Configuration: Mac OS X Safari 419.3
L'ennoncé entier est ici :
|
Salut,
#! /bin/bash
# enlever-des-lignes.sh
# Déclaration fonction d'usage
fonction_usage ()
{
echo -e "\tUsage : $0 [n|n-n]\n"
echo -e "\tn est un entier positif."
echo -e "\tn-n est un intervalle (eg. 6-15)"
echo -e "\tLes entiers seront séparés par un espace.\n\
Les intervalles n-n séparés par un tiret \"-\".\n"
}
# Test existence fichier
if [ ! -e "$1" ]; then
echo -e "Le fichier $1 n'existe pas ! \n"
fonction_usage
exit 2
fi
# Test nombre de paramètres
if [ "$#" -lt 2 ]; then
echo -e "Nombre de paramètres incorrects ! \n\n"
fonction_usage
exit 3
fi
# Test entier positif et/ou mauvais intervalle
for n in "$@"; do
case "$n" in
-* ) echo -e "Les entiers doivent être de type positif !\n"
fonction_usage
exit 4
;;
*-* ) var1=$(echo $n | cut -d- -f1)
var2=$(echo $n | cut -d- -f2)
if [ "$var1" -gt "$var2" ]; then
echo -e "Erreur dans l'intervalle \"$n\"\n"
fonction_usage
exit 5
fi
;;
[0-9]*[!-][0-9]* ) echo -e "Le caractère séparateur d'intervalle n'est pas un tiret !\n"
fonction_usage
exit 6
;;
esac
done
##### Début du script #####
# Initialisation variable fichier (pour libérer le paramètres $1)
fichier=$1
# Décalage des paramètres
shift
# Initialisation des paramètres en passant par :
#+ substitution espace par saut de ligne
#++ tri numérique
#+++ substitution saut de ligne par espace et
#++++ substitution tiret par virgule
set $(echo "$@" | sed 's/ /\n/g'| sort -n | sed -e :a -e '$!N;s/\n/ /;ta' -e 's/-/,/g')
# Initialisatieon compteur
n=1
# Initialisation variable "cmd" (sed)
cmd="sed "
# Boucle tant que compteur inférieur au nombre de paramètres
while [ "$n" -le "$#" ]
do
# On rajoute à la variable "cmd" le reste de la commande sed
cmd="$cmd-e ''\$$n'd' "
# On incrémente le compteur
n=$(expr $n + 1)
done
# On exécute la commande (cmd) qui doit ressembler pour 4 paramètres initiaux à :
#+ sed -e ''$1'd ' -e ''$2'd ' -e ''$3'd ' $fichier
eval $cmd $fichier
;-))
Z'@+...che. JP : Zen, my Nuggets ! ;-) Le savoir n'est bon que s'il est partagé.
|