Otras soluciones en esta página no son deseables si tiene una larga lista de extensiones (mantener una secuencia larga -not -name 'this' -not -name 'that' -not -name 'other'
sería tediosa y propensa a errores) o si la búsqueda es programática y la lista de extensiones está construida en tiempo de ejecución.
Para esas situaciones, find
puede ser deseable una solución que separe más claramente los datos (la lista de extensiones) y el código (los parámetros para ). Dado un directorio y una estructura de archivos que se ve así:
.
└── a
├── 1.txt
├── 15.xml
├── 8.dll
├── b
│ ├── 16.xml
│ ├── 2.txt
│ ├── 9.dll
│ └── c
│ ├── 10.dll
│ ├── 17.xml
│ └── 3.txt
├── d
│ ├── 11.dll
│ ├── 18.xml
│ ├── 4.txt
│ └── e
│ ├── 12.dll
│ ├── 19.xml
│ └── 5.txt
└── f
├── 13.dll
├── 20.xml
├── 6.txt
└── g
├── 14.dll
├── 21.xml
└── 7.txt
Puedes hacer algo como esto:
## data section, list undesired extensions here
declare -a _BADEXT=(xml dll)
## code section, this never changes
BADEXT="$( IFS="|" ; echo "${_BADEXT[*]}" | sed 's/|/\\|/g' )"
find . -type f ! -regex ".*\.\($BADEXT\)"
Lo que resulta en:
./a/1.txt
./a/b/2.txt
./a/b/c/3.txt
./a/d/4.txt
./a/d/e/5.txt
./a/f/6.txt
./a/f/g/7.txt
Puede cambiar la lista de extensiones sin cambiar el bloque de código.
NOTA no funciona con OSX nativo find
: utilice gnu find en su lugar.
-not
puede ser reemplazado por'!'
(se recomienda cotizar). Por otro lado,-name
es sensible a-iname
mayúsculas y minúsculas.