.png)
Tengo un awk
guión new.awk
:
BEGIN { FS = OFS = "," }
NR == 1 {
for (i = 1; i <= NF; i++)
f[$i] = i
}
NR > 1 {
begSecs = mktime(gensub(/[":-]/, " ", "g", $(f["DateTime"])))
endSecs = begSecs + $(f["TotalDuration"])
$(f["CallEndTime"]) = strftime("%Y-%m-%d %H:%M:%S", endSecs)
}
{ print }
Estoy llamando a esto en shell
awk new.awk sample.csv
... pero puedo ver los cambios en la terminal. ¿Cómo realizar el cambio in situ en el archivo, como cuando se usa sed -i
?
Respuesta1
GNU awk
(comúnmente encontrado en sistemas Linux), desde la versión 4.1.0, puede incluir una " awk
biblioteca fuente" con -i
o --include
en la línea de comando (ver¿Cómo utilizar de forma segura la opción -i de gawk o la directiva @include?junto con el comentario de Stéphane a continuación para cuestiones de seguridad relacionadas con esto). Una de las bibliotecas fuente que se distribuye con GNU awk
se llama inplace
:
$ cat file
hello
there
$ awk -i inplace '/hello/ { print "oh,", $0 }' file
$ cat file
oh, hello
Como puede ver, esto hace que la salida del awk
código reemplace el archivo de entrada. La línea que dice there
no se mantiene porque el programa no la genera.
Con un awk
script en un archivo, lo usarías como
awk -i inplace -f script.awk datafile
Si la awk
variable INPLACE_SUFFIX
se establece en una cadena, entonces la biblioteca haría una copia de seguridad del archivo original con eso como sufijo de nombre de archivo.
awk -i inplace -v INPLACE_SUFFIX=.bak -f script.awk datafile
Si tiene varios archivos de entrada, cada archivo se editará individualmente en el lugar. Pero puedes desactivar la edición in situ para un archivo (o un conjunto de archivos) usando inplace=0
la línea de comando antes de ese archivo:
awk -i inplace -f script.awk file1 file2 inplace=0 file3 inplace=1 file4
En el comando anterior, file3
no se editaría en su lugar.
Para una "edición in situ" más portátil de un solo archivo, utilice
tmpfile=$(mktemp)
cp file "$tmpfile" &&
awk '...some program here...' "$tmpfile" >file
rm "$tmpfile"
Esto copiaría el archivo de entrada a una ubicación temporal, luego aplicaría el awk
código en el archivo temporal mientras se redirige al nombre del archivo original.
Realizar las operaciones en este orden (ejecutar awk
en el archivo temporal, no en el archivo original) garantiza que los metadatos del archivo (permisos y propiedad) del archivo original no se modifiquen.
Respuesta2
Prueba esto.
awk new.awk sample.csv > tmp.csv && mv -f tmp.csv sample.csv
- redirigir la salida a un archivo temporal.
- luego mueva el contenido del archivo temporal al archivo original.