Estoy usando el siguiente comando en mi mac:
$find . -name “*.java” -exec sed -i ’s/foo/bar/g’ {} \;
y parece no tener efecto.
Tengo dos archivos en el directorio que terminan en .java, que tienen el texto foo en ellos. ¿Me estoy perdiendo de algo?
EDITAR: Resultados de la solicitud de comentarios
[aafghani-03:~/test amirafghani]$ find . -name "*.java" -exec sed -i 's/foo/bar/g' {} \;
sed: 1: "./bar.java": invalid command code .
sed: 1: "./foo.java": invalid command code .
-exec
y todo después? ¿Imprime los nombres de los archivos Java? (Me preocupa que estés usando comillas inteligentes en lugar de comillas ASCII)"
y'
, respectivamente.Respuestas:
En primer lugar, asegúrese de usar comillas ascii regulares como
"
y'
(códigos ascii0x22
y0x27
, respectivamente) en los scripts de shell, porque el ejemplo en su publicación contiene caracteres de comillas no estándar. Si te fijas bien, se ven un poco diferentes. Lo más probable es que se trate de un error de copiar y pegar de un formato de documento de texto enriquecido como Word, OOWriter o incluso una ventana del navegador.Como estás en una Mac, es probable que tengas la implementación de FreeBSD
sed
, en cuyo caso debes escribir el comando de esta manera:(aquí usando en
+
lugar de\;
evitar ejecutar unased
invocación por archivo).En la implementación de FreeBSD,
sed
el-i
indicador necesita un argumento: la extensión de un archivo de respaldo. Por ejemplo, con-i .bak
el comando realizaría una copia de seguridadfile1.txt
comofile1.txt.bak
primero antes de realizar el reemplazo en el archivo original. Usar un argumento vacío''
significa no usar un archivo de copia de seguridad, que parece ser lo que desea.Lo mismo en la implementación de GNU (o NetBSD, OpenBSD, busybox) sería:
Gracias @bahamat y @Mikel y @ pieter-breed por mejorar mi respuesta con sus comentarios.
fuente