因為后臺錄入的同事,上傳文件的時候,給文件取了相同的名字,但不同的后綴名,由于文件路徑非常深,大概十層左右,每一層又有幾十個文件,所以人工找起來非常麻煩,所以寫了個腳本,幫他們實現查找指定目錄下所有子目錄及文件,找出相同文件名,不同后綴的文件,然后,手動保留其中一個。
代碼如下:
#!/bin/bash
#判斷一下腳本參數的問題
if [ $# -ne 1 ];then
echo "Usage find_same.sh direcroty"
exit
fi
find $1 -type d > /tmp/dir.txt
#將所有需要查詢的目錄本身和子目錄的名字存儲在一個臨時文件里
#對每個目錄進行比較查詢
while read dir
do
find $dir -maxdepth 1 -type f > /tmp/file.txt
#將當前目錄下的所有文件存儲在臨時文件里
awk -F '/' '{print $NF}' /tmp/file.txt | awk -F '[.]' '{print $1}'| sort | uniq -d > /tmp/filename.txt
#把文件名字取出來,有同樣名字的就把名字放到/tmp/filename.txt里
line=`wc -l /tmp/filename.txt | awk '{print $1}'`
#判斷一下該文件里一共有多少行,每一行就是一個重名的文件名
#輸出
echo "The directory $dir including same name file: "
if [ $line -ge 1 ] ; then
while read name
do
filename=`grep $name /tmp/file.txt`
echo "$filename"
echo $filename >> /tmp/samefile.txt
#所有的記錄存放在這個文件里
done < /tmp/filename.txt
fi
done < /tmp/dir.txt
模擬測試:
linux-8hij:/tmp/test # ll
total 4
-rw-r--r-- 1 root root 0 Mar 9 02:04 1.png
-rw-r--r-- 1 root root 0 Mar 9 02:04 1.txt
drwxr-xr-x 2 root root 4096 Mar 9 02:05 test1
linux-8hij:/tmp/test/test1 # ll
total 0
-rw-r--r-- 1 root root 0 Mar 9 02:05 11.jpg
-rw-r--r-- 1 root root 0 Mar 9 02:05 11.log
-rw-r--r-- 1 root root 0 Mar 9 02:05 2.log
運行結果:
linux-8hij:/tmp # ./find_name.sh /tmp
The directory /tmp including same name file:
The directory /tmp/.ICE-unix including same name file:
新聞熱點
疑難解答