Modifier le séparateur d'un fichier CSV - Paul Courbis

Modifier le séparateur d’un fichier CSV

vendredi 22 janvier 2010, par Paul Courbis

#!/bin/sh

cat in.csv | awk '
BEGIN { OLD_FS=","; NEW_FS=";"; FS=OLD_FS; RS="\n"; OFS=""; }
{
       IN="no";
       for(i=1; i<=NF; i++)
       {
          if ( IN == "no" && i > 1 ) printf ("%s", NEW_FS );
          if ( IN == "no" && substr($i, 1, 1) == "\"" ) IN="yes";
          printf( "%s", $i );
          if ( IN == "yes" )
          {
             if( substr($i, length($i), 1)  == "\"" ) IN="no";
             else printf( "%s", OLD_FS );
          }
       }
       printf ( "\n" );
}' > out.csv

Répondre à cet article