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 :

Plusieurs lignes vers une seule au format CSV


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2015
    Messages
    151
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2015
    Messages : 151
    Par défaut Plusieurs lignes vers une seule au format CSV
    Bonjour,

    Je suis toujours débutant en script shell.

    J'ai les données suivantes comme input :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    83644701
    CR
    032
    026955764
    LI3-28872
    Et je veux avoir le résultat suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    83644701;CR;032;026955764;LI3-28872
    Mon effort :

    Résultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    83644701;
    CR;
    032;
    026955764;
    LI3-28872;
    C'est pas comme je veux !!!

    Merci d'avance.

  2. #2
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 716
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 716
    Par défaut
    Bonjour,

    « en input » c'est un fichier, ou les paramètres d'un script ?

  3. #3
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2015
    Messages
    151
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2015
    Messages : 151
    Par défaut
    Citation Envoyé par N_BaH Voir le message
    Bonjour,

    « en input » c'est un fichier, ou les paramètres d'un script ?
    Oui c'est un fichier

  4. #4
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 716
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 716
    Par défaut
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $ read -a ar < <(echo $(<fichier.input ))
    $ var=$(IFS=';'; echo "${ar[*]}")
    $ echo "$var"
    83644701;CR;032;026955764;LI3-28872

  5. #5
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 408
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 408
    Par défaut
    Citation Envoyé par N_BaH Voir le message
    Code bash : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $ read -a ar < <(echo $(<fichier.input ))
    $ var=$(IFS=';'; echo "${ar[*]}")
    $ echo "$var"
    83644701;CR;032;026955764;LI3-28872
    Hmmm, dans le cas suivant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    83644701
    CR TOTO
    032
    026955764
    LI3-28872
    J'obtiens:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    83644701;CR;TOTO;032;026955764;LI3-28872
    Sinon, en bash, plus simple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $ ar="`<fichier.input`"
    $ var="${ar//
    /;}"
    $ echo $var
    83644701;CR TOTO;032;026955764;LI3-28872

  6. #6
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 716
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 716
    Par défaut
    attention, ar n'est alors plus un tableau, il est préférable de renommer la variable, pour éviter toute ambiguïté :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $ var="`<fichier.in`"
    $ var="${var//$'\n'/;}"
    $ echo "$var"
    83644701;CR TOTO;032;026955764;LI3-28872
    pour rester sur un tableau :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $ unset ar; while read line; do ar+=( "$line" ); done < fichier.in 
    $ var=$(IFS=';'; echo "${ar[*]}")
    $ echo "$var"
    83644701;CR TOTO;032;026955764;LI3-28872
    c'est un peu plus lourd. :/

  7. #7
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 408
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 408
    Par défaut
    En gnu sed (pas testé) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -n ':A;$s/\n/;/gp;N;bA'
    PS:La prochaine fois, crée un nouveau sujet car là tu es hors sujet...

Discussions similaires

  1. copier des plages variables de plusieurs feuilles vers une seule
    Par irene15 dans le forum Macros et VBA Excel
    Réponses: 19
    Dernier message: 22/06/2007, 14h44
  2. Plusieurs lignes dans une seule
    Par rlnd23 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 07/02/2007, 17h35
  3. [MySQL] Remplir plusieurs lignes d'une seule table avec le même formulaire
    Par zehni dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 07/09/2006, 13h12
  4. Réponses: 4
    Dernier message: 14/09/2005, 17h29
  5. Concatenation de plusieurs lignes en une seule
    Par stawen dans le forum Langage SQL
    Réponses: 2
    Dernier message: 31/03/2005, 14h55

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