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

Unix Discussion :

Shell - Report d'1 champ sur plusieurs lignes


Sujet :

Unix

  1. #1
    Candidat au Club
    Inscrit en
    Décembre 2010
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Décembre 2010
    Messages : 8
    Points : 2
    Points
    2
    Par défaut Shell - Report d'1 champ sur plusieurs lignes
    Bonjour,

    J'ai un fichier à format fixe que je dois charger sous Oracle en SQL*Loader. Mon fichier contient différents types de lignes (défini par le 1er caractère) : une ligne d'entête (type A) et des lignes de détail (type B ou C). Avant le chargement, le fichier est découpé en 3 : les entêtes d'un côté et les 2 différents types de détail de l'autre, qui partiront vers 3 tables différentes ensuite sous Oracle.

    Problème : je dois reporter un champ de la ligne d'entête vers ses lignes de détails. Et impossible de le faire après sous Oracle car ce champ sert justement à faire le lien entre les 2 tables. L'ordre du fichier est séquentiel soit :
    A Entête1 Champ_a_reporter
    B Détail1
    C Détail1
    A Entête2 Champ_a_reporter
    B Détail2
    ...

    => L'objectif est donc de reporter un champ de la ligne de type A vers toutes ses lignes de types autres que A (soit celles qui précèdent la prochaine ligne de type A).

    Est-ce réalisable en shell ? et si oui je veux bien un peu d'aide parce que je sèche là

    Merci d'avance

  2. #2
    Membre chevronné

    Homme Profil pro
    Responsable projets techniques
    Inscrit en
    Février 2003
    Messages
    980
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable projets techniques
    Secteur : Biens de consommation

    Informations forums :
    Inscription : Février 2003
    Messages : 980
    Points : 1 894
    Points
    1 894
    Par défaut
    pas sur d'avoir tout compris, mais voilà peut-être un début de réponse ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $ cat test.txt
    A Entête1 Champ_a_reporter
    B Détail1
    C Détail1
    A Entête2 Champ_a_reporter
    B Détail2
    $ awk '$1=="A" {entete=$2} $1!="A" {print entete" "$0}' test.txt
    Entête1 B Détail1
    Entête1 C Détail1
    Entête2 B Détail2

  3. #3
    Candidat au Club
    Inscrit en
    Décembre 2010
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Décembre 2010
    Messages : 8
    Points : 2
    Points
    2
    Par défaut
    Citation Envoyé par Alek-C Voir le message
    pas sur d'avoir tout compris, mais voilà peut-être un début de réponse ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $ cat test.txt
    A Entête1 Champ_a_reporter
    B Détail1
    C Détail1
    A Entête2 Champ_a_reporter
    B Détail2
    $ awk '$1=="A" {entete=$2} $1!="A" {print entete" "$0}' test.txt
    Entête1 B Détail1
    Entête1 C Détail1
    Entête2 B Détail2
    Oui c'est à peu près ça merci.
    J'avais une autre solution en fait toujours avec awk et un substr (fichier au format fixe) donc je la met ici pour info (le champ est ajouté en fin de ligne) :

    awk '/^A/ {c=substr($0, 11, 17);print;next} {print $0, c} ' test.txt

Discussions similaires

  1. AWK Comparer un champ sur plusieurs lignes
    Par drac08 dans le forum Shell et commandes GNU
    Réponses: 4
    Dernier message: 21/08/2012, 18h03
  2. La meme valeur dans un champ sur plusieurs lignes
    Par JeanduB dans le forum Access
    Réponses: 8
    Dernier message: 15/05/2008, 14h52
  3. [SSRS] cangrow -- champ sur plusieurs lignes
    Par marie253 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 23/11/2007, 08h27
  4. Réponses: 12
    Dernier message: 25/09/2007, 17h22
  5. Réponses: 9
    Dernier message: 11/09/2007, 10h08

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