Précédent   Forum des professionnels en informatique > Systèmes > Linux > Applications > Shell
Shell Vos questions sur l'utilisation des commandes shell
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 31/01/2012, 17h54   #1
 
Inscription : janvier 2012
Messages : 12
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 12
Points : -4
Points : -4
Par défaut Supprimer des lignes d'un fichier selon la valeur d'un substr d'une colonne

j'ai aussi une autre question dans le même contexte: Je voudrais supprimer des lignes selon la valeur de la première colonne,

par exemple:

read jd (jour début) supposon que $jd=15
read jf (jour fin) // // $jf=18

on a le fichier suivant en INPUT:

14/01/2012;a;b;c;d
15/01/2012;a;b;c;d
16/01/2012;a;b;c;d
17/01/2012;a;b;c;d
18/01/2012;a;b;c;d
19/01/2012;a;b;c;d
20//01/2012;a;b;c;d

je voudrais avoir en OUTPUT:

15/01/2012;a;b;c;d
16/01/2012;a;b;c;d
17/01/2012;a;b;c;d
18/01/2012;a;b;c;d

toutes les autres lignes seront supprimées. Merci de me répondre, je vous serai reconnaissant
powertay11 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/01/2012, 18h01   #2
Expert Confirmé
 
Inscription : janvier 2011
Messages : 970
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : janvier 2011
Messages : 970
Points : 2 871
Points : 2 871
Salut,

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$ cat plop 
14/01/2012;a;b;c;d
15/01/2012;a;b;c;d
16/01/2012;a;b;c;d
17/01/2012;a;b;c;d
18/01/2012;a;b;c;d
19/01/2012;a;b;c;d
20//01/2012;a;b;c;d
 
$ sed -n '/^15/,/^18/p' plop 
15/01/2012;a;b;c;d
16/01/2012;a;b;c;d
17/01/2012;a;b;c;d
18/01/2012;a;b;c;d
 
$
__________________
$ man woman
Il n'y a pas de page de manuel pour woman.
zipe31 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/02/2012, 22h00   #3
 
Inscription : janvier 2012
Messages : 12
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 12
Points : -4
Points : -4
Citation:
Envoyé par zipe31 Voir le message
Salut,

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$ cat plop 
14/01/2012;a;b;c;d
15/01/2012;a;b;c;d
16/01/2012;a;b;c;d
17/01/2012;a;b;c;d
18/01/2012;a;b;c;d
19/01/2012;a;b;c;d
20//01/2012;a;b;c;d
 
$ sed -n '/^15/,/^18/p' plop 
15/01/2012;a;b;c;d
16/01/2012;a;b;c;d
17/01/2012;a;b;c;d
18/01/2012;a;b;c;d
 
$
Merci bcp mais j'ai un petit souci, la date est affichée en anglais 2012-01-15
le nombre en question se trouve en dernière position au lieu d'être au début de la ligne...Merci de m'aider!!!
powertay11 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/02/2012, 23h19   #4
Expert Confirmé
 
Inscription : janvier 2011
Messages : 970
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : janvier 2011
Messages : 970
Points : 2 871
Points : 2 871
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$ cat plop
2012-01-14;a;b;c;d
2012-01-15;a;b;c;d
2012-01-16;a;b;c;d
2012-01-17;a;b;c;d
2012-01-18;a;b;c;d
2012-01-19;a;b;c;d
2012-01-20;a;b;c;d
 
$ sed -n '/15;/,/18;/p' plop 
2012-01-15;a;b;c;d
2012-01-16;a;b;c;d
2012-01-17;a;b;c;d
2012-01-18;a;b;c;d
 
$
__________________
$ man woman
Il n'y a pas de page de manuel pour woman.
zipe31 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/02/2012, 10h46   #5
 
Inscription : janvier 2012
Messages : 12
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 12
Points : -4
Points : -4
Citation:
Envoyé par zipe31 Voir le message
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
$ cat plop
2012-01-14;a;b;c;d
2012-01-15;a;b;c;d
2012-01-16;a;b;c;d
2012-01-17;a;b;c;d
2012-01-18;a;b;c;d
2012-01-19;a;b;c;d
2012-01-20;a;b;c;d
 
$ sed -n '/15;/,/18;/p' plop 
2012-01-15;a;b;c;d
2012-01-16;a;b;c;d
2012-01-17;a;b;c;d
2012-01-18;a;b;c;d
 
$
Merci pour cette solution mais j'ai pas exactement ";" après le jour j'ai plutôt une heure (2012-01-15 10:09:12), et les jours précisés dans le sed peuvent ne pas exister dans le fichier genre le 15 et le 18 peuvent ne pas exister dans le fichier....
powertay11 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/02/2012, 10h50   #6
Expert Confirmé
 
Inscription : janvier 2011
Messages : 970
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : janvier 2011
Messages : 970
Points : 2 871
Points : 2 871
Tu as le principe, à toi d'adapter en fonction de tes besoins.

Par contre si les jours n'existent pas, ben t'auras rien en sortie
__________________
$ man woman
Il n'y a pas de page de manuel pour woman.
zipe31 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/02/2012, 11h53   #7
 
Inscription : janvier 2012
Messages : 12
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 12
Points : -4
Points : -4
Exactement :s il me sort rien
powertay11 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 11/02/2012, 22h39   #8
 
Inscription : janvier 2012
Messages : 12
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 12
Points : -4
Points : -4
y a t-il une autre solution ?
powertay11 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/02/2012, 01h20   #9
Membre habitué
 
Avatar de Levi59
 
Homme
Étudiant
Inscription : août 2011
Messages : 46
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : août 2011
Messages : 46
Points : 126
Points : 126
un petit exemple en bash qui devrait fonctionner (à adapter selon tes besoins):
Code :
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
#!/bin/bash
 
search() { 
    i=$1
    j=$2
    until [[ -n $(grep $i plop) ]]
    do 
        ((i++))
        (($i>$j)) && {
            echo "pas de correspondance"
            exit 0
        }
    done
 
    (($j==$i)) && {
        echo "une seule correspondance"
        echo $(grep $j plop)
        exit 0
    }
 
    until [[ -n $(grep $j plop) ]]
    do 
        ((j--))
        (($j==$i)) && {
            echo "une seule correspondance"
            echo $(grep $j plop)
            exit 0
        }
    done
    sed -n '/'$i';/,/'$j';/p' plop
}
search $1 $2
Ce qui donne :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
akira@virtualcrunchbang:~$ cat plop
2012-01-14;a;b;c;d
2012-01-16;a;b;c;d
2012-01-17;a;b;c;d
2012-01-18;a;b;c;d
2012-01-19;a;b;c;d
2012-01-20;a;b;c;d
2012-01-31;a;b;c;d
akira@virtualcrunchbang:~$ ./plop.sh 15 20
2012-01-16;a;b;c;d
2012-01-17;a;b;c;d
2012-01-18;a;b;c;d
2012-01-19;a;b;c;d
2012-01-20;a;b;c;d
akira@virtualcrunchbang:~$ ./plop.sh 19 25
2012-01-19;a;b;c;d
2012-01-20;a;b;c;d
__________________
Carpe Diem
Levi59 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/02/2012, 02h42   #10
Expert Confirmé Sénior
 
Avatar de N_BaH
 
Inscription : février 2008
Messages : 2 072
Détails du profil
Informations forums :
Inscription : février 2008
Messages : 2 072
Points : 4 155
Points : 4 155
Bonjour,

Code bash :
1
2
3
#!/bin/bash
 
while IFS="-" read y m reste; do d="${reste%%;*}"; (( d >= $1 && d <=$2 )) && echo "$y-$m-$reste"; done <plop
je vous laisse ajouter les tests pour être sûr que $1 est inférieur à $2, qu'ils sont bien des nombres, etc.

si le fichier est volumineux, ce code doit pouvoir être adapté très facilement en awk.
N_BaH est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 11h27.


 
 
 
 
Partenaires

Hébergement Web