shell 文本和文件批量处理

来源:互联网 发布:数据库如何优化 编辑:程序博客网 时间:2024/04/27 17:25

将文件名中包含aa-aa-的字符去掉:

#!/bin/bash
CATCH_STRING='aa-aa-*'
for i in $(find ./* -name $CATCH_STRING)
do 
NEWNAME=$(echo $i | sed -e 's/aa-aa-//')
echo $NEWNAME
mv $i $NEWNAME
done


显示一个文件中的include文件和其存放路径

#!/bin/bash
for i in $(find ./* -name '*.*')
do
echo
echo
echo
echo '%%%%%%%%%%%%%%%%%FILE' $i 'INCLUDED SERCHER%%%%%%%%%%%%%%%%%'
cat $i | grep -r '#include' >>FILE2
awk '{print $2}' FILE2 >>FILE1


# cat FILE1
echo  >FILE2
while read LINE
do
echo $LINE | sed -e 's/<//' >>FILE2
done<FILE1


# cat FILE2
echo  >FILE1
while read LINE
do
echo $LINE | sed -e 's/>//' >>FILE1
done<FILE2


# cat FILE1
echo  >FILE2
while read LINE
do
echo $LINE | sed -e 's/"//' >>FILE2
done<FILE1


# cat FILE2
echo  >FILE1
sed -i '/^[[]]\+$/d' FILE2
sed -i '/^$/d' FILE2
# cat FILE2
while read LINE
do
FILE_NAME=$(basename $LINE)
# echo $FILE_NAME
FILE_PATH=$(dirname $LINE)
# echo $FILE_PATH
echo 
echo '********************FIND' $LINE 'RESULTS*********************'
echo 
find /usr/include/* -name $FILE_NAME
done<FILE2


echo  >FILE2


done


在一个文件夹中使用aa-aa-标志文件名筛选出与另一个文件夹中相对应的文件。

#!/bin/bash


for i in $(find ./* -name "aa-aa-*")
do
NEW_FILE=$(echo $i | sed -e 's/_xiugai/_primery/')
PRI_FILE=$(echo $NEW_FILE | sed -e 's/aa-aa-//')
echo  $NEW_FILE
mv $PRI_FILE $NEW_FILE
done


将文件中include路径的下划线翻转:

#!/bin/bash
INPUT_ARG1=$1
STR="*"
SER_FOLDER=${INPUT_ARG1}${STR}
for i in $(find $SER_FOLDER -name "*")
do
echo "$i"
sed -i '/include/ {s/\//\\/g}' $i
done


0 0
原创粉丝点击