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 :

Changer les colonnes en ligne d'un fichier txt


Sujet :

Shell et commandes GNU

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2019
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2019
    Messages : 12
    Points : 15
    Points
    15
    Par défaut Changer les colonnes en ligne d'un fichier txt
    Bonjour,

    J'ai un fichier texte comme suit:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    A B C D E
    1 2 3 4 5
    11 22 33 44 55
    et je veux avoir comme sortie:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    A 1 11
    B 2 22
    C 3 33
    D 4 44
    E 5 55
    Est-ce qu'il y a une possibilité de le faire avec une commande linux ou un script shell ?
    Merci d'avance

  2. #2
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2019
    Messages
    12
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2019
    Messages : 12
    Points : 15
    Points
    15
    Par défaut
    Re bonjour

    J'ai trouvé la solution je la poste ci-dessous au cas ou quelqu'un en aurait besoin

    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
    awk '
    { 
        for (i=1; i<=NF; i++)  {
            a[NR,i] = $i
        }
    }
    NF>p { p = NF }
    END {    
        for(j=1; j<=p; j++) {
            str=a[1,j]
            for(i=2; i<=NR; i++){
                str=str" "a[i,j];
            }
            print str
        }
    }' Apprentissage.csv > test-app.csv

  3. #3
    Expert éminent sénior Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 243
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 243
    Points : 13 459
    Points
    13 459
    Par défaut
    Bonjour

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $ cat fichier.txt
    A B C D E
    1 2 3 4 5
    11 22 33 44 55
    $ csvtool -t ' ' -u ' ' transpose fichier.txt
    A 1 11
    B 2 22
    C 3 33
    D 4 44
    E 5 55
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

  4. #4
    Membre éprouvé Avatar de balkany
    Homme Profil pro
    Touriste
    Inscrit en
    Juillet 2017
    Messages
    346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Touriste

    Informations forums :
    Inscription : Juillet 2017
    Messages : 346
    Points : 977
    Points
    977
    Par défaut
    La commande csvtool n'a pas l'air disponible dans toutes les distributions. Sous Ubuntu oui, mais sous Arch non. Même sur AUR, il n'y a que csvtools, qui ne fournit apparemment pas cette commande.

  5. #5
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 286
    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 286
    Points : 12 742
    Points
    12 742
    Par défaut
    Une autre solution awk:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk '{A=A" "$0}END{l=split(A,b);while(++i<=NF){for(j=i;j<=l;j+=NF){printf("%s ",b[j])};print ""}}' fichier
    Cordialement.

  6. #6
    Membre éprouvé Avatar de balkany
    Homme Profil pro
    Touriste
    Inscrit en
    Juillet 2017
    Messages
    346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Touriste

    Informations forums :
    Inscription : Juillet 2017
    Messages : 346
    Points : 977
    Points
    977
    Par défaut
    La solution proposée par kakdim en #2 est plus générale, car les lignes ne sont pas obligées de faire le même nombre de colonnes.
    En voici une variante qui répartit le travail différemment (avec l'ajout d'une mise en forme par la commande column à la fin) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk '{NR==1?q=NF:q=p; NF>p?p=NF:""; for(i=1;i<=q;i++){a[i]=a[i]$i" "}; for(i=q+1;i<=p;i++){a[i]=s$i" "}; s=s" "}; END{for(i=1;i<=p;i++){printf("%s\n",a[i])}}' fichier | column -t -s ' '

Discussions similaires

  1. Changer les couleur de ligne d'un fichier kml
    Par hocine dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 02/08/2018, 10h38
  2. Réponses: 21
    Dernier message: 05/02/2018, 01h09
  3. Requête SQL : Afficher les colonnes en ligne, et vice versa
    Par paflolo dans le forum Langage SQL
    Réponses: 7
    Dernier message: 17/03/2009, 09h16
  4. Récupérer les X dernières lignes de mon fichier txt
    Par coincoin22 dans le forum Windows
    Réponses: 0
    Dernier message: 08/08/2007, 14h39
  5. [JTable] Changer les colonnes de manière dynamique
    Par gg2laba dans le forum Composants
    Réponses: 3
    Dernier message: 03/10/2005, 23h39

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