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 :

[bash] Extraire des lignes d'une catégorie souhaitée (sans awk)


Sujet :

Shell et commandes GNU

Mode arborescent

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Invité
    Invité(e)
    Par défaut [bash] Extraire des lignes d'une catégorie souhaitée (sans awk)
    Bonjour,
    Je ne parviens pas à extraire, à partir d’un champ d’un fichier ‘livres’ les différents enregistrements selon la catégorie de livres souhaitée par la personne (j’ai déjà écrit la partie du script où il faut read la catégorie du livre souhaitée par une personne et j’ai déjà récupéré les données de chaque champ).
    !!!Je ne dois pas utiliser de awk pour cet exercice qui se fait en bash… Merci à eux qui m’aideront

    Par exemple j’ai ceci,
    Nom1: Prénom1:TITRE1:2000:BD
    Nom2: Prénom2:TITRE2:2001:ROMAN
    Nom3: Prénom3:TITRE3:2002:SCIENCES
    Nom4: Prénom4:TITRE4:2003:BD
    Nom5: Prénom5:TITRE5:2004:ROMAN
    Nom6: Prénom6:TITRE6:2004:SCIENCES
    Et à la fin de mon script, je dois créer un fichier dans lequel :
    - la première ligne va m’indiquer la liste des auteurs (1re et 2e colonne) et titres de livres(3e colonne) de la catégorie (4e colonne)
    - les lignes suivantes m’indiquent le nom de l'auteur(1re colonne) ainsi que le titre des livres de la catégorie sélectionnée(3e colonne) , séparés par un -
    - la dernière ligne indique le nombre de livres trouvés

    Voici ce que j’ai déjà essayé de faire (en m’imaginant pour ‘ROMAN’) :
    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
    	#créer le fichier reprenant titre liste de livres et nombres de livres extraits
     
    	ISFold=$IFS
    	IFS=':'
    	while read nom prenom titre annee categorie
    	do
    	  function creer_fichier {
    		touch -p "/home/livres/$1"
     
    		if grep -q "^$1:" /etc/group
    		then
    			ls -l | head -1 /home/user/livres | cut -d: -f1,4 /home/user/livres
     
    		elif 
    			ls -l | tail -n+2 /home/user/livres | cut -d: -f1 "-" -f3 /home/user/livres
    		else
    			ls | wc -l | tail -1 /home/user/livres
    		fi
    		resultat=$(grep -l student/home/user/livres/*)
    	}
    	done < /home/user/livres
     
    done
    Dernière modification par Invité ; 16/07/2022 à 16h55. Motif: Ajout des balises CODE (bouton #) et QUOTE

Discussions similaires

  1. [XL-2010] Extraire des lignes d'une colonne situées entre 2 mots constants
    Par xico8 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 03/02/2015, 10h07
  2. Extraire des lignes avec une formule
    Par maxxxime dans le forum Excel
    Réponses: 9
    Dernier message: 15/06/2010, 17h05
  3. [XL-2007] Extraire des lignes en fonction d'une valeur de cellule dans un autre fichier
    Par MisterTambo dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 19/08/2009, 10h42
  4. Réponses: 3
    Dernier message: 21/01/2009, 13h49
  5. Extraire des lignes d'un fichier en commande bash
    Par newnew dans le forum Linux
    Réponses: 3
    Dernier message: 27/07/2004, 16h22

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