linux 批量替换文件内容及查找某目录下所有包含某字符串的文件(批量修改文件内容)

来源:互联网 发布:matlab cell数组 编辑:程序博客网 时间:2024/05/18 00:09

From: http://justcoding.iteye.com/blog/1948005

1. sed

C代码  收藏代码
  1. grep -rl matchstring somedir/ | xargs sed -i 's/string1/string2/g'  

 

例如:

 

对象:文件夹

C代码  收藏代码
  1. grep -rl 'windows' ./path | xargs sed -i 's/windows/linux/g'  

 

2. find

对象:文件

C代码  收藏代码
  1. find -name 'test' | xargs perl -pi -e 's|windows|linux|g'  

 

 这里使用了perl语言,使用-e加上一段代码,从而批量地将当前目录及所有子目录下的file.log文件中的string1替换成了string2; string支持正则表达式
 

3. awk

C代码  收藏代码
  1. grep -i "windows" -r ./path | awk -F : '{print $1}' | sort | uniq | xargs sed -i 's/windows/linux/g'  
 这里使用了shell命令,先查找出文件,再用awk分割(以:切分),再行替换!
注意:   grep可以使用正则,也可以使用\转义一些特殊字符,比如“等  
sed -i 's/\"localhost\"/\"10.2.2.2\"/g' /home/my.conf
更多:

 

sed replace word / string syntax

The syntax is as follows:

C代码  收藏代码
  1. sed -i 's/old-word/new-word/g' *.txt  

 

GNU sed command can edit files in place (makes backup if extension supplied) using the -i option. If you are using an old UNIX sed command version try the following syntax:

C代码  收藏代码
  1. sed 's/old/new/g' input.txt > output.txt  

 

You can use old sed syntax along with bash for loop:

C代码  收藏代码
  1. #!/bin/bash  
  2. OLD="xyz"  
  3. NEW="abc"  
  4. DPATH="/home/you/foo/*.txt"  
  5. BPATH="/home/you/bakup/foo"  
  6. TFILE="/tmp/out.tmp.$$"  
  7. [ ! -d $BPATH ] && mkdir -p $BPATH || :  
  8. for f in $DPATH  
  9. do  
  10.   if [ -f $f -a -r $f ]; then  
  11.     /bin/cp -f $f $BPATH  
  12.    sed "s/$OLD/$NEW/g" "$f" > $TFILE && mv $TFILE "$f"  
  13.   else  
  14.    echo "Error: Cannot read $f"  
  15.   fi  
  16. done  
  17. /bin/rm $TFILE  

 

A Note About Bash Escape Character

A non-quoted backslash \ is the Bash escape character. It preserves the literal value of the next character that follows, with the exception of newline. If a \newline pair appears, and the backslash itself is not quoted, the \newline is treated as a line continuation (that is, it is removed from the input stream and effectively ignored). This is useful when you would like to deal with UNIX paths. In this example, the sed command is used to replace UNIX path "/nfs/apache/logs/rawlogs/access.log" with "__DOMAIN_LOG_FILE__":

C代码  收藏代码
  1. #!/bin/bash  
  2. ## Our path  
  3. _r1="/nfs/apache/logs/rawlogs/access.log"  
  4.    
  5. ## Escape path for sed using bash find and replace   
  6. _r1="${_r1//\//\\/}"  
  7.    
  8. # replace __DOMAIN_LOG_FILE__ in our sample.awstats.conf  
  9. sed -e "s/__DOMAIN_LOG_FILE__/${_r1}/" /nfs/conf/awstats/sample.awstats.conf  > /nfs/apache/logs/awstats/awstats.conf  
  10.    
  11. # call awstats  
  12. /usr/bin/awstats -c /nfs/apache/logs/awstats/awstats.conf  

 

The $_r1 is escaped using bash find and replace parameter substitution syntax to replace each occurrence of /with \/.

 

perl -pie Syntax For Find and Replace

The syntax is as follows:

C代码  收藏代码
  1. perl -pie 's/old-word/new-word/g' input.file > new.output.file  

 

来源:http://www.cyberciti.biz/faq/unix-linux-replace-string-words-in-many-files/

 

linux下查找某目录下所有文件包含某字符串的命令

C代码  收藏代码
  1. #从文件内容查找匹配指定字符串的行:  
  2. $ grep "被查找的字符串" 文件名  
  3.   
  4. #从文件内容查找与正则表达式匹配的行:  
  5. $ grep –e “正则表达式” 文件名  
  6.   
  7. #查找时不区分大小写:  
  8. $ grep –i "被查找的字符串" 文件名  
  9.   
  10. #查找匹配的行数:  
  11. $ grep -c "被查找的字符串" 文件名  
  12.   
  13. #从文件内容查找不匹配指定字符串的行:  
  14. $ grep –v "被查找的字符串" 文件名  
  15.   
  16. #从根目录开始查找所有扩展名为.txt的文本文件,并找出包含"linux"的行  
  17. find . -type f -name "*.txt" | xargs grep "linux" 
0 0