linux目錄比對
思路:將每層目錄取出做統一處理,得到所有目錄之後,統計目錄下文件個數並輸出到文件,將比對的兩個文件目錄的文件去除收個目錄結構,數據對比,刪除一致數據,返回一個不一致文件,並將文件重命名為目錄結構文件
處理方案(代碼如下)
#!/bin/bash
rm -rf /mnt/1.txt /mnt/2.txt /mnt/3.txt /mnt/4.txt /mnt/5.txt /mnt/6.txt #刪除上次數據
read -p "your contents1: " content1 #讀取目錄
ls -lR $content1 | grep / |awk -F : '{print $1}' > /mnt/1.txt #所有將目錄的輸出
read -p "your contents2: " content2 #讀取比對目錄
ls -lR $content2 | grep / |awk -F : '{print $1}' > /mnt/2.txt
for i in `cat /mnt/1.txt` #統計每層目錄下的個數
do
echo $i'#'`ls -l $i/ | wc -l` >> 3.txt
done
for i in `cat /mnt/2.txt`
do
echo $i'#'`ls -l $i/ | wc -l` >> 4.txt
done
sed -i "s#/#;#g" /mnt/3.txt #替換/為;
sed -i "s#/#;#g" /mnt/4.txt
awk -F ';hds' '{print $2}' /mnt/4.txt >> /mnt/5.txt #按初級目錄做分隔
awk -F ';adba' '{print $2}' /mnt/3.txt >> /mnt/6.txt
for i in `cat /mnt/5.txt` #數據比對
do
for y in `cat /mnt/6.txt`
do
if [ $i == $y ];then
sed -i "/$i/d" /mnt/6.txt
fi
done
done
sed -i 's#;#/#g' /mnt/6.txt #將;切回/以便觀察
sed -i s#^#/adba#g /mnt/6.txt #加回初級目錄
mv /mnt/6.txt `echo $content1 | awk -F / '{print $2"_"$3"_"$4"_"$5"_"$6"_"$7"_"$8 }'` #更改文件為目錄層級文件
linux目錄比對