|
Publicité ' | ||||||||||||||||||||||||
|
|
#21 |
|
Expert Confirmé
![]() ![]() Inscription : avril 2009 Messages : 2 633 ![]() |
Le bug, c'est que si on sélectionne la dernière colonne et qu'on la place avant la fin, les lignes seront coupées en deux. Et même si on la met en dernier, comme dans le fichier d'origine, on aura une ligne vide sur deux.
__________________
Plus j'apprends, et plus je mesure mon ignorance (philou67430) Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book) Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé Using strict and warnings is good for you. |
|
|
00
|
|
|
#22 |
![]() ![]() ![]() Inscription : avril 2004 Messages : 13 489 ![]() |
modification effectuée dans les sources. C'est ok pour toi ?
__________________
|
|
|
00
|
|
|
#23 |
|
Expert Confirmé
![]() ![]() Inscription : avril 2009 Messages : 2 633 ![]() |
Oui, ça me semble parfait. Par contre, j'ai pas refait d'essai... Il aurait été intéressant dans l'article de mettre un exemple de csv
__________________
Plus j'apprends, et plus je mesure mon ignorance (philou67430) Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book) Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé Using strict and warnings is good for you. |
|
|
00
|
|
|
#24 |
![]() ![]() ![]() Inscription : avril 2004 Messages : 13 489 ![]() |
Je ne suis pas contre un autre exemple de csv. Si tu en as un sous la main, met le sur ce fil et je le rajoute dans la source.
__________________
|
|
|
00
|
|
|
#25 |
|
Expert Confirmé
![]() ![]() Inscription : avril 2009 Messages : 2 633 ![]() |
En fait, c'est OK, j'ai récupéré le fichier de test avec un copier/coller et je l'ai testé avec la dernière colonne en premier : tout baigne (et il y avait bien un bug).
__________________
Plus j'apprends, et plus je mesure mon ignorance (philou67430) Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book) Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé Using strict and warnings is good for you. |
|
|
00
|
|
|
#26 | |
![]() ![]() ![]() Inscription : avril 2004 Messages : 13 489 ![]() |
Citation:
__________________
|
|
|
|
00
|
|
|
#27 | |
|
Membre Expert
![]() |
Citation:
Je viens de tomber sur ce sujet, et je vais peut-être dire une bêtise, mais pourquoi ne pas utiliser l'option "-a" dans ce cas ? Est-ce parce qu'elle n'est pas disponible partout ? Avec l'exemple cité, ceci semble fonctionner (tout du moins sous Linux) : Code :
perl -naF';' -e 'print "$F[8] $F[0]\n"' fichier.csv |
|
|
|
00
|
|
|
#28 |
|
Expert Confirmé
![]() ![]() Inscription : avril 2009 Messages : 2 633 ![]() |
Tout bonnement parce que je ne connaissais pas ces options -a et -F
Il faut naturellement utiliser ces options qui simplifient l'uniligne d'origine : Code :
perl -naF';' -e 'chomp;print join qq( ), @F[8,0], $/' fichier.csv
__________________
Plus j'apprends, et plus je mesure mon ignorance (philou67430) Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book) Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé Using strict and warnings is good for you. |
|
|
00
|
|
|
#29 |
|
Expert Confirmé
![]() ![]() Inscription : avril 2009 Messages : 2 633 ![]() |
En fait, c'est plus compliqué que cela, le chomp n'est pas fait, et l'introduire sur $_ ne fonctionne pas : il faut le faire sur $F[$#F], ce qui alourdit légèrement l'uniligne (il serait logique que -a fasse le chomp).
Code bash :
perl -naF';' -e 'chomp($F[$#F]);print join qq( ), @F[8,0], $/' fichier.csv
__________________
Plus j'apprends, et plus je mesure mon ignorance (philou67430) Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book) Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé Using strict and warnings is good for you. |
|
|
00
|
|
|
#30 |
|
Expert Confirmé
![]() ![]() Inscription : avril 2009 Messages : 2 633 ![]() |
Au final, l'option -l nous sauve la vie, et fait le chomp avant que l'option -a découpe l'entrée :
Code :
perl -nlaF';' -e 'print join qq( ), @F[8,0], $/' fichier.csv
__________________
Plus j'apprends, et plus je mesure mon ignorance (philou67430) Toute technologie suffisamment avancée est indiscernable d'un script Perl (Llama book) Partagez vos problèmes pour que l'on partage ensemble nos solutions : je ne réponds pas aux questions techniques par message privé Using strict and warnings is good for you. |
|
|
00
|
|
|
#31 |
![]() ![]() ![]() Inscription : avril 2004 Messages : 13 489 ![]() |
-l permet le traitement automatique des fins de ligne. Cette option a deux effets :
Utilisée avec -n ou -p, elle fait automatiquement un chomp au début de la boucle implicite. Elle affecte à $\ (le séparateur d'enregistrements en sortie) le caractère dont la valeur octale a été passée. Si aucune valeur octale n'est donnée, l'option met $\ à la valeur courante de $/. Cette affectation $\ = $/ est faite au moment où l'option est rencontrée. Le séparateur d'enregistrements en entrée peut donc être différent du séparateur en sortie si l'option -l est suivie par l'option -0.
__________________
|
|
|
00
|
|
|
#32 |
|
Membre Expert
![]() |
Je crois aussi qu'on peut utiliser $F[-1] pour le dernier élément d'un tableau (au lieu de $F[$#F]) ce que je trouve personnellement un peu plus parlant (et surtout, on peut aussi utiliser -2 -3... Mais là encore, je ne sais pas si c'est compatible partout ! |
|
|
00
|
|
|
#33 | ||
![]() ![]() ![]() Inscription : avril 2004 Messages : 13 489 ![]() |
On pourrait expliquer que le code
Code :
perl -nlaF';' -e 'print join qq( ), @F[8,0], $/' fichier.csv Code :
__________________
|
||
|
|
20
|
|
|
#34 |
|
Membre Expert
![]() |
ça peut être une bonne chose
|
|
|
00
|
|
|
#35 | |||
![]() ![]() ![]() Inscription : avril 2004 Messages : 13 489 ![]() |
sinon petit bug :
Code csv :
Sous Windows Code :
perl -nlaF';' -e "print join q(-), @F[8,0], $/" test.csv Citation:
__________________
|
|||
|
|
00
|
|
|
#36 |
|
Membre Expert
![]() |
J'ai l'impression qu'avec l'option -l, il ne faut pas afficher le saut de lignes :
Code :
perl -nlaF';' -e 'print join qq( ), @F[8,0]' fichier.csv (ton code donnait la même chose sous Linux djibril) Edit, bon, en fait, c'est exactement ce que fait $/ (que je ne connaissais pas |
|
|
10
|
|
|
#37 | |
![]() ![]() ![]() Inscription : avril 2004 Messages : 13 489 ![]() |
Citation:
![]() Je modifierais qq{ } en q{ }. Il n'y a pas d'interpolation, donc qq est inutile.
__________________
|
|
|
|
00
|
|
|
#38 |
![]() ![]() ![]() Inscription : avril 2004 Messages : 13 489 ![]() |
Alek-C, je t'ajoute dans les auteurs des sources
. Tes futurs propositions sont les bienvenues.
__________________
|
|
|
00
|
|
|
#39 | |
|
Membre Expert
![]() |
Citation:
) :pPlus sérieusement, c'est avec plaisir que je penserais à ce topic, j'utilise souvent des petits scripts perl pour éviter de jongler entre les différentes versions de sed/awk/grep qu'on trouve selon les OS, et si certains me semblent utiles, je viendrais les soumettre ici sans problème ! Par contre, il y aura sans doute des retouches à faire |
|
|
|
00
|
|
|
#40 |
![]() ![]() ![]() Inscription : avril 2004 Messages : 13 489 ![]() |
__________________
|
|
|
10
|
Copyright © 2000-2013 - www.developpez.com