查找不包含“* .sql”文件的目录

时间:2015-10-27 13:53:08

标签: linux bash find

我有几个目录如下。我想列出没有SQL文件的目录。例如下面的示例中的“dev.mysite.com”。我使用的是ubuntu 14.04 LTS

orange.com/
    orange.com.sql
    10.10.10.1/public_html/...

apple.edu.us/
    apple.edu.sql
    10.10.10.2/public_html/...

dev.mysite.com/
    10.10.10.3/public_html/

example.com/
    mysql_dbdump20150911.sql
    10.10.11.11/public_html/...

我尝试使用“find”和“cut”和“xargs”来实现这一点,并将这些目录移动到“dirwithsql”目录,并将剩余的目录作为没有sql文件的目录。

find . -maxdepth 2 -iname "*.sql" | cut -d'/' -f 2 | xargs -n 1 -I {} mv {} /backup/dirwithsql/{}

我试过

find -maxdepth 2 ! -iname "*.sql" -exec dirname {} \;

但是上面的命令显示所有目录

还有更好的方法吗? 谢谢

2 个答案:

答案 0 :(得分:1)

我最近遇到过类似的问题,这对我有用

for f in $(find . -type d -maxdepth 2); do if [[ $(ls -1 $f | grep '.sql$'|wc -l) == 0 ]] ; then echo $f; fi; done

答案 1 :(得分:0)

find . -type d -print0 | while read -d $'\0' n; do [ -f "$n"/*.sql ] || echo $n; done

即使使用异国情调的目录名称(空格,换行符......)也可以使用