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

Solaris Discussion :

Garder les lignes les plus récentes


Sujet :

Solaris

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 6
    Points : 2
    Points
    2
    Par défaut Garder les lignes les plus récentes
    Hello,

    Mon soucis est relativement simple, j'ai un fichier dans ce style :

    ID1,totoNew,tutuNew,totoNew
    ID3,azea,aze,aze
    ID1,toto,tutu,toto
    L'idée est de le trier en supprimant les doublons sur clef. Dans un script j'effectue un sort -u sur l'id :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort -t ',' -u -k 1,1 test.txt
    J'avais fais des tests et trouvé que totoNew apparraissait toujours en premier, mais je viens de lire dans le man du sort :

    sort does not guarantee preservation of relative line order-ing on equal keys.
    En refaisant des tests, je me rends compte que le traitement des doublons sur clef est en effet assez aléatoire. Quelqu'un aurait une idée de comment récupérer les derniers enregistrement rapidement ? J'ai déjà essayé des solutions avec parcours de tous les ids avec des grep pour voir s'il apparaissait plus loins dans le fichier, mais vu la volumétrie, c'est bien trop gourmand pour pouvoir satisfaire mes besoins.

    Merci d'avance pour toute aide éventuelle.

    Yannick

  2. #2
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Points : 28 121
    Points
    28 121
    Par défaut
    Hum, je n'ai pas bien compris ce que tu veux faire...

    Tu veux ne garder qu'une seule ligne contenant chaque motif ?

  3. #3
    Modérateur
    Avatar de jlliagre
    Homme Profil pro
    Ingénieur support avancé & développement
    Inscrit en
    Juin 2007
    Messages
    2 695
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur support avancé & développement
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 695
    Points : 7 842
    Points
    7 842
    Par défaut
    Ca devrait le faire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    awk '{printf("%d,%s\n",i++,$0);}' test.txt |
    sort -t ',' -k 2,2 | awk -F, '
    {
    	idx=$2
    	$1=""
    	line=$0
    	if(idx!=oldidx && oldidx!=0) printf("%s\n",oldline);
    	oldidx=idx;
    	oldline=line;
    }
    END {
    	printf("%s\n",oldline);
    }
    '

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 6
    Points : 2
    Points
    2
    Par défaut
    Merci beaucoup jlliagre, ça m'a l'air de faire exactement ce que je veux :-) Je vais faire des tests avec de plus gros volumes dans la journée, je mettrai une note si tout va bien, ou si tout ne va pas bien aussi d'ailleurs En tout cas, merci !

Discussions similaires

  1. Réponses: 6
    Dernier message: 20/10/2013, 11h37
  2. Lister les lignes les plus récentes
    Par narglix dans le forum Langage SQL
    Réponses: 4
    Dernier message: 22/04/2010, 12h33
  3. Trouver la ligne la plus récente
    Par youba11 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 04/10/2009, 01h06
  4. [AC-2000] Garder l'enregistrement le plus récent
    Par MelaAllIn dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 18/08/2009, 16h23
  5. Récupérer la ligne la plus récente
    Par DeezerD dans le forum Requêtes
    Réponses: 2
    Dernier message: 01/04/2007, 13h13

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