微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

bash – 在目录层次结构中查找并删除重复的文件名

#!/bin/sh
LASTBASE=""  
find $1 -type f -print | rev | sort | rev | while read FILE
do
    BASE=$(basename "$FILE")
    if [ "$BASE" = "$LASTBASE" ]; then
        rm "$FILE"
    LASTBASE="$BASE"
done
如果将find的输出传输到while循环中,则可以逐行处理它们:
find nnn/ -type f -print | rev | sort | rev | while read FILE; do
    ...
done

编辑:因此,如果文件名包含双(连续)空格,则此方法会中断,因为read实际上根据$IFS将行拆分,然后在存储最后一个变量时再次连接它.要解决此问题,您可以暂时更改$IFS以禁用拆分:

OIFS="$IFS"
IFS=""
find | while read...
IFS="$OIFS"

编辑:test(与[相同]没有==运算符,你只需要=.

原文地址:https://www.jb51.cc/bash/385486.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐