A voir également:
- Awk: longueur de record
- Awk dédoublonner un print ✓ - Forum Shell
- Suppression de lignes en awk ✓ - Forum Shell
- Awk : tri selon la date ✓ - Forum Shell
- SED ou Awk sous windows ?? - Forum Windows
- Shell - Utilisation de variable avec awk ✓ - Forum Shell
12 réponses
Salut,
si la commande que je t'ai donné avec perl ça ne marche pas alors je n'ai pas compris la question
si seulement le résultat compte et pas la méthode et le fichier n'est pas confidentiel, je te propose de mettre le fichier sur cjoint.com
si la commande que je t'ai donné avec perl ça ne marche pas alors je n'ai pas compris la question
si seulement le résultat compte et pas la méthode et le fichier n'est pas confidentiel, je te propose de mettre le fichier sur cjoint.com
Salut Lami20j,
Le prob est que ce sont des données financieres, et donc a caractere privé.
Ne pourrais tu pas m'aider avec awk ? length ?
Merci d'avance
Le prob est que ce sont des données financieres, et donc a caractere privé.
Ne pourrais tu pas m'aider avec awk ? length ?
Merci d'avance
awk je ne connais pas
essaie
lami20j
essaie
cat fichier| perl -ne 'print join "\n",unpack("A4000" x (length($_)/4000), $_)' > resultat--
lami20j
je viens d'executer,
il separe bien les records "idem dd"
mais complete pas les records pour en faire des lignes de 4000 blocs.
As tu une autre idée awk ou sed ?
il separe bien les records "idem dd"
mais complete pas les records pour en faire des lignes de 4000 blocs.
As tu une autre idée awk ou sed ?
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
mais complete pas les records pour en faire des lignes de 4000 blocs.
alors j'avoue que je ne comprends pas ta question
Je te propose de créer un fichier avec des lignes de 7caractères et de le transformer en 3 blocs pour voir ce que tu cherches
alors j'avoue que je ne comprends pas ta question
Je te propose de créer un fichier avec des lignes de 7caractères et de le transformer en 3 blocs pour voir ce que tu cherches
moi j'ai compris qu'il faut mettre un \n après chaque 4000 caractère
alors c'est ça que fait les commandes que j'ai donné
et je pense que la tienne aussi
alors c'est ça que fait les commandes que j'ai donné
et je pense que la tienne aussi
Ouf j'ai trouvé et grace a toi
voici la commande qui realise la transformation correcte:
dd if=file_in cbs=4000 conv=unblock | awk '{printf("%4000s\n", $0)}' > file_out
oui je sais un dd pipé avec un awk c'est pas trop propre mais ca marche ;-)
Mille merci
voici la commande qui realise la transformation correcte:
dd if=file_in cbs=4000 conv=unblock | awk '{printf("%4000s\n", $0)}' > file_out
oui je sais un dd pipé avec un awk c'est pas trop propre mais ca marche ;-)
Mille merci
écoute il y a 2 caractères à prendr en consideration
CR
LF
et ensuite
CRLF
si tu veux avec CR alors c'est \r
si tu veux avec LF c'est \n
si tu veux avec CRLF alors c'est \r\n
ce qui veut dire que les commandes
doivent fonctionner selon les besoins
CR
LF
et ensuite
CRLF
si tu veux avec CR alors c'est \r
si tu veux avec LF c'est \n
si tu veux avec CRLF alors c'est \r\n
ce qui veut dire que les commandes
cat fichier| perl -ne 'print join "\n",unpack("A4000" x (length($_)/4000), $_)' > resultat_n cat fichier| perl -ne 'print join "\r",unpack("A4000" x (length($_)/4000), $_)' > resultat_r cat fichier| perl -ne 'print join "\r\n",unpack("A4000" x (length($_)/4000), $_)' > resultat_rn
doivent fonctionner selon les besoins