KSH : mise en forme colonne vers format csv
Résolu
dofre114
-
dubcek Messages postés 19021 Statut Contributeur -
dubcek Messages postés 19021 Statut Contributeur -
Bonjour à tous,
J'ai un petit souci de mise en forme , j'aurai besoin d'un script sur
J'ai besoin de l'avoir au format csv sous ce type :
Merci d'avance pour votre aide
J'ai un petit souci de mise en forme , j'aurai besoin d'un script sur
ksh. J'ai un fichier de type :
BEGIN
A=toto
B=tata
H=titi
END
BEGIN
A=toto
B=titi
C=tata
D=toto
END
BEGIN
D=toto
E=titi
F=tata
G=tutu
H=tete
END
J'ai besoin de l'avoir au format csv sous ce type :
A;B;C;D;E;F;G;H
toto;tata;;;;;;titi
toto;titi;tata;toto;;;;;
;;;;toto;titi;tata;tutu;tete
Merci d'avance pour votre aide
A voir également:
- KSH : mise en forme colonne vers format csv
- [Ksh] Différence entre deux heures - Forum Shell
- Difference entre sh ksh et bash - Forum Shell
- Executer des requetes sql dans un .ksh ✓ - Forum Shell
2 réponses
Bonjour,
Je te propose cette solution, écrite en python, car en shell c'est un peu "compliqué" à écrire surtout si tu n'as pas d'a priori sur les clés impliquées dans ton fichier.
... ce qui donne à l'exécution.
Bonne chance
Je te propose cette solution, écrite en python, car en shell c'est un peu "compliqué" à écrire surtout si tu n'as pas d'a priori sur les clés impliquées dans ton fichier.
#!/usr/bin/env python3
import sys
filename = sys.argv[1]
entries = list()
keys = set()
entry = dict()
with open(filename) as f:
for line in f.readlines():
line = line.strip()
if line == "BEGIN":
entry = dict()
elif line == "END":
entries.append(entry)
else:
sp = line.split("=")
assert len(sp) > 1
key = sp[0]
value = "".join(sp[1:])
entry[key] = value
keys.add(key)
keys = sorted(keys)
print(";".join(keys))
print("\n".join(
";".join(
entry.get(key, "")
for key in keys
)
for entry in entries
))
... ce qui donne à l'exécution.
(mando@silk) (~) $ python3 toto.py fichier.txt
A;B;C;D;E;F;G;H
toto;tata;;;;;;titi
toto;titi;tata;toto;;;;
;;;toto;titi;tata;tutu;tete
Bonne chance
hello
$ cat f3.awk
BEGIN { s=split("A B C D E F G H", t); FS="="}
/BEGIN/ {++n; next}
/=/ {t2[n][$1]=$2}
END {for(x=1; x<=s; x++)printf "%s%c", t[x], x==s? "\n": ";"
for(x=1; x<=n; x++)for(z=1; z<=s; z++)printf "%s%c", t2[x][t[z]], z==s? "\n": ";"}
$
$ awk -f f3.awk fichier.txt
A;B;C;D;E;F;G;H
toto;tata;;;;;;titi
toto;titi;tata;toto;;;;
;;;toto;titi;tata;tutu;tete