
Estoy intentando convertir el siguiente formato de A a B, donde puede ver que las dos primeras columnas se intercambian en el formato final junto con sus datos intactos y se canalizan entre ellas y la parte complicada es la última en la que se cambia el formato de fecha. 2016-09-06 08:49:00 al "06/09/2016 08:49:00 a. m.". Estoy usando bash shell y necesito un script para hacer lo mismo.
A:
Display Name,SAM Account Name,Distinguished Name,Last Logon Time Stamp
Yolanda Perez,yperez1,"CN=Yolanda Perez,OU=Users,OU=PR - Miami SPCG,OU=PR - Puerto Rico,OU=Puerto Rico,OU=Caribbean - Unified,DC=intl,DC=bns",2016-09-06 08:49:00
B:
"SAM Account Name"|"Display Name"|"Distinguished Name"|"Last Logon Time Stamp"
"yperez1"|"Yolanda Perez,CN=Yolanda Perez"|"OU=Users,OU=PR - Miami SPCG,OU=PR - Puerto Rico,OU=Puerto Rico,OU=Caribbean - Unified,DC=intl,DC=bns"|"09/06/2016 08:49:00 AM"
Respuesta1
Creo que intentar hacerlo únicamente en bash sería bastante complicado.
Existe un programa csvfix
que debería hacer la mayor parte del trabajo por usted:http://neilb.bitbucket.org/csvfix/
Respuesta2
La siguiente respuesta se basa enesteyeste.
#!/bin/bash
awk -vFPAT='([^,]*)|("[^"]+")' -vOFS=, '{
if (NR == 1) {
print "\""$2"\"" "|" "\""$1"\"" "|" "\"" $3 "\"" "|" "\""$4"\""
} else {
cmd ="date \"+%m/%d/%Y %H:%M:%S %p\" -d \""$4"\""
cmd | getline var
close(cmd)
print "\""$2"\"" "|" "\""$1"\"" "|"$3"|" "\""var"\""
}
}' data.csv
Aquí data.csv
está el archivo de entrada ( A
en su ejemplo). Ejecute el script anterior (llamado csv2pipe.sh
) como:
bash csv2pipe.sh
. El resultado se muestra a continuación.
"SAM Account Name"|"Display Name"|"Distinguished Name"|"Last Logon Time Stamp"
"yperez1"|"Yolanda Perez"|"CN=Yolanda Perez,OU=Users,OU=PR - Miami SPCG,OU=PR - Puerto Rico,OU=Puerto Rico,OU=Caribbean - Unified,DC=intl,DC=bns"|"09/06/2016 08:49:00 AM"
Respuesta3
Conperl
perl -MTime::Piece -F, -alne '
print $.==1? "\"".join("\"|\"", $F[1], $F[0], @F[2..$#F])."\""
: join("|", "\"".$F[1]."\"", "\"".join(",", $F[0], substr($F[2],1))."\"", "\"".join(",", @F[3..9]), Time::Piece->strptime($F[10], "%Y-%m-%d %H:%M:%S")->strftime("\"%m/%d/%Y %H:%M:%S %p\""))
' file.csv
"SAM Account Name"|"Display Name"|"Distinguished Name"|"Last Logon Time Stamp"
"yperez1"|"Yolanda Perez,CN=Yolanda Perez"|"OU=Users,OU=PR - Miami SPCG,OU=PR - Puerto Rico,OU=Puerto Rico,OU=Caribbean - Unified,DC=intl,DC=bns"|"09/06/2016 08:49:00 AM"