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 :

Réorganiser un tableau en une seule colonne


Sujet :

Shell et commandes GNU

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2020
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2020
    Messages : 4
    Points : 3
    Points
    3
    Par défaut Réorganiser un tableau en une seule colonne
    Bonjour à tous.

    Je cherche à traiter des données d'un programme avec un autre programme. Le problème c'est que les données de sortie du premier n'ont pas un format adéquat pour être directement entrées dans le second. J'obtiens un tableau ASCII très jolie à l'oeil mais très difficile à faire comprendre à un code de cette forme avec des séparateurs différents (confidentiel je ne peux pas vous le montrer directement) :
    100 200 300 400 500
    1 2 3 4 5
    10 20 30 40 50

    Ce que j'aimerais faire donc, c'est prendre chaque colonne une par une et les mettre à la suite les unes des autres sur la même colonne comme ceci :
    100
    1
    10
    200
    2
    ...

    Pour cela j'ai voulu utiliser un script AWK mais je n'arrive pas obtenir le résultat souhaité. Je réussis bien à avoir une seule colonne mais pas dans le bon ordre. C'est à dire que j'ai la 1ére valeur de la collone 1, la 1ère valeur de la colonne 2, la 1ère valeur de la colnne 3 etc... J'ai essayé plusieurs écritures mais je ne connais pas bien awk donc j'obtiens sans cesse le même résultat. Ce serait donc pour savoir si vous pouviez m'aider sur ce point avec AWK ou même avec un autre code s'il est capable de faire ça facilement.

    Merci à vous

  2. #2
    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 458
    Points
    13 458
    Par défaut
    Bonjour

    mais très difficile à faire comprendre à un code de cette forme avec des séparateurs différents
    Ce bout de phrase cité a-t-il un sens en bon français ? Et en informatique ?

    Sais-tu ce qu'est une tabulation ? C'est un seul caractère. N'est-ce pas ?

    De toute façon, le bon conseil est de t'empêcher de faire ce que tu dis vouloir faire. Le format du fichier que tu cherches à obtenir est plus pourri que le fichier original.

    Finalement, quel est le vrai but final ?
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

  3. #3
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 278
    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 278
    Points : 12 726
    Points
    12 726
    Par défaut
    Techniquement, un fichier texte, est une suite de ligne et non de colonne, donc là, tu es obligé de charger la totalité du fichier dans un tableau à 2 dimension par exemple, où ton premier index sera la ligne et le deuxième la colonne.
    Cordialement.

  4. #4
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2020
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2020
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Citation Envoyé par Flodelarab Voir le message
    Bonjour

    Ce bout de phrase cité a-t-il un sens en bon français ? Et en informatique ?
    Effectivement pour moi devant mon ordinateur ça me paraissait clair ce que j'ai dis mais ça ne l'est pas vraiment en fait. Ce que je veux dire c'est que mon tableau final est constituée de colonnes qui sont séparés de plusieurs manières différentes, parfois c'est un espace, parfois une flèche ou encore une virgule. De ce fait le 2ème programme que je souhaite utiliser est incapable de lire un tel fichier mais est capable de lire un fichier constitué d'une seule colonne.
    En revanche il peut aussi lire les fichiers d'une seule ligne avec un séparateur unique donc, à la vue de ce que dit disedorgue, il serait surement plus pertinent de le faire de cette manière.

    Merci.

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 550
    Points : 19 383
    Points
    19 383
    Par défaut
    les séparateurs sont "aléatoires", mais connus ?
    alors tu pourrais les changer en un séparateur "unique", avec un sed intercalé entre les programmes...
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  6. #6
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2020
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2020
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Je ne connaissais pas du tout sed, je suis encore trop peu expérimenté en Linux. Je vais essayer mais ça m'a l'air intéressant comme technique.
    Merci

  7. #7
    Expert éminent Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 035
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 035
    Points : 8 400
    Points
    8 400
    Par défaut
    salut,

    Citation Envoyé par Nattend22 Voir le message
    j'ai voulu utiliser un script AWK mais je n'arrive pas obtenir le résultat souhaité
    je prends un fichier d'entrée hypothétique :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    100     200 ,300,; 400   500
    1,2 , 3         4 5
    10 ;=) 20,30,,,40-50
    un exemple via awk :
    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
    $ awk -F'[^0-9]+' '
    > {
    >    for (i = 1; i <= NF; i++) {
    >       arr[i,NR] = $i
    >    }
    > }
    >
    > END {
    >    for (column = 1; column <= NF; column++) {
    >       print "colonne " column " :"
    >       for (row = 1; row <= NR; row++) {
    >          print arr[column,row]
    >       }
    >    }
    > }' fichier
    et le résultat :
    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
    17
    18
    19
    20
    colonne 1 :
    100
    1
    10
    colonne 2 :
    200
    2
    20
    colonne 3 :
    300
    3
    30
    colonne 4 :
    400
    4
    40
    colonne 5 :
    500
    5
    50

  8. #8
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2020
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2020
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Incroyable c'est pile ce que je cherchais, j'ai vraiment galéré avec les tableaux en AWK.

    Merci à vous tous de m'avoir aider.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 2
    Dernier message: 04/07/2019, 12h41
  2. Réponses: 3
    Dernier message: 08/03/2017, 10h38
  3. [XL-2010] Avoir une seule colonne d'un tableau avec un fond colorée à la fois
    Par AnthonyGG dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 29/01/2015, 13h24
  4. [XL-2000] Transposition d'un tableau excel variable en une seule colonne
    Par Boldug dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 27/05/2011, 16h08
  5. Formatage d'une seule colonns d'un tableau
    Par Général03 dans le forum Mise en page CSS
    Réponses: 6
    Dernier message: 04/03/2009, 18h23

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