Chinaunix首页 | 论坛 | 博客
  • 博客访问: 892376
  • 博文数量: 73
  • 博客积分: 2689
  • 博客等级: 少校
  • 技术积分: 897
  • 用 户 组: 普通用户
  • 注册时间: 2010-10-07 19:39
个人简介

一个有目标,为自己的未来努力奋斗的人

文章分类
文章存档

2015年(9)

2014年(2)

2013年(6)

2012年(11)

2011年(33)

2010年(12)

分类: Python/Ruby

2012-07-30 10:05:52

source:

如果你在shell命令行下,需要一种能快速查找并替换多个文件里字符的方法,
那么下面这行命令你一定要记住或者收藏起来,它能帮到你的。

find . -name '*.html' -print0 | xargs -0 perl -pi -e 's/SEARCHSTRING/REPLACESTRING/g'

注解:
*.html:表示查找所在目录下的所有扩展名为html的文件;
SEARCHSTRING:要查找搜索的字符;
REPLACESTRING:替换后的字符。

记住:如果替换的字符包括 ()[]/"'!? 等等这样的特殊字符,你必须在字符前加上反斜杠\ 。

使用举例:

1.创建一个新目录:

$ mkdir test
$ cd test

2.创建1.html,2.html两个文件,并分别输入i like china :

[root@localhost test]$ vi 1.html

按i进入输入模式,输入:

i like china

按esc键退出输入模式,输入

:wq

退出。

[root@localhost test$] vi 2.html

按i进入输入模式,输入:

you like china

按esc键退出输入模式,输入

:wq

退出。

3.运行替换命令,like感情不够强烈,呵呵,我们这里要将2个文件中的字符 like 换为 love :

[root@localhost test]$ find . -name '*.html' -print0 | xargs -0 perl -pi -e 's/like/love/g'

4.检查替换结果:

[root@localhost test]$ cat 1.html
i love china

[root@localhost test]$ cat 2.html
you love china

(the end)


另附转载博文:

批量修改文件名后缀

http://linux.chinaunix.net/techdoc/develop/2005/04/15/922097.shtml

可以复习一下xargs的用法,和变量的一些高级操作技巧
如何批量把若干文件从一个扩展名改为另一个扩展名?比如把后缀gz,改为zip
答:
1.for file in *.gz; do mv $file `basename $file .gz`.zip; done 
或(也适合ksh) 
for file in *.gz; do mv $file ${file%.gz}.zip; done
2.ls | grep gz | awk -F'.' '{print $1}'|xargs -i mv {}.gz {}.zip
附netman十三问片断:
${file#*/}:拿掉第一条 / 及其左边的字符串:dir1/dir2/dir3/my.file.txt 
${file##*/}:拿掉最后一条 / 及其左边的字符串:my.file.txt 
${file#*.}:拿掉第一个 . 及其左边的字符串:file.txt 
${file##*.}:拿掉最后一个 . 及其左边的字符串:txt 
${file%/*}:拿掉最后条 / 及其右边的字符串:/dir1/dir2/dir3 
${file%%/*}:拿掉第一条 / 及其右边的字符串:(空值) 
${file%.*}:拿掉最后一个 . 及其右边的字符串:/dir1/dir2/dir3/my.file 
${file%%.*}:拿掉第一个 . 及其右边的字符串:/dir1/dir2/dir3/my 
记忆的方法为: 
# 是去掉左边(在鉴盘上 # 在 $ 之左边) 
% 是去掉右边(在鉴盘上 % 在 $ 之右边) 
单一符号是最小匹配﹔两个符号是最大匹配。
${file:0:5}:提取最左边的 5 个字节:/dir1 
${file:5:5}:提取第 5 个字节右边的连续 5 个字节:/dir2 
我们也可以对变量值里的字符串作替换: 
${file/dir/path}:将第一个 dir 提换为 path:/path1/dir2/dir3/my.file.txt 
${file//dir/path}:将全部 dir 提换为 path:/path1/path2/path3/my.file.txt 
利用 ${ } 还可针对不同的变量状态赋值(没设定、空值、非空值): 
${file-my.file.txt} :假如 $file 没有设定,则使用 my.file.txt 作默认值。(保留空值及非空值) 
${file:-my.file.txt} :假如 $file 没有设定或为空值,则使用 my.file.txt 作默认值。 (保留非空值) 
${file+my.file.txt} :不管 $file 为何值,均使用 my.file.txt 作默认值。 (不保留任何值) 
${file:+my.file.txt} :若 $file 为非空值,则使用 my.file.txt 作传回值。 (保留没设定及空值) 
${file=my.file.txt} :若 $file 没设定,则使用 my.file.txt 作默认值,同时将 $file 定义为非空值。 (保留空值及非空值) 
${file:=my.file.txt} :若 $file 没设定或为空值,则使用 my.file.txt 作默认值,同时将 $file 定义为非空值。 (保留非空值) 
${file?my.file.txt} :若 $file 没设定,则将 my.file.txt 输出至 STDERR。 (保留空值及非空值)) 
${file:?my.file.txt} :若 $file 没设定或为空值,则将 my.file.txt 输出至 STDERR。 (保留非空值) 
还有哦,${#var} 可计算出变量值的长度: 
${#file} 可得到 27 ,因为 /dir1/dir2/dir3/my.file.txt 刚好是 27 个字节... 
接下来,再为大家介稍一下 bash 的组数(array)处理方法。 
一般而言,A="a b c def" 这样的变量只是将 $A 替换为一个单一的字符串, 
但是改为 A=(a b c def) ,则是将 $A 定义为组数... 
bash 的组数替换方法可参考如下方法: 
${A[@]} 或 ${A
} 可得到 a b c def (全部组数) 
${A[0]} 可得到 a (第一个组数),${A[1]} 则为第二个组数... 
${#A[@]} 或 ${#A
} 可得到 4 (全部组数数量) 
${#A[0]} 可得到 1 (即第一个组数(a)的长度),${#A[3]} 可得到 3 (第四个组数(def)的长度) 
A[3]=xyz 则是将第四个组数重新定义为 xyz ...

#####################################################

#/bin/bash
#i=118
for((j=110;j<146;j++))
do
   path="/home/education/$j/img"
   cd "$path"
echo `pwd`
    ls 0?.jpg > tmp.txt
    for i in `cat tmp.txt`
do
    mv $i `echo $i |cut -c 2-6`
    done
done

#########################################

#/bin/bash
#i=118
for((j=86;j<146;j++))
do
   path="/home/education/$j/img"
   cd "$path"
echo `pwd`
    ls ?.jp > tmp.txt
    for i in `cat tmp.txt`
do
#    mv $i `echo $i |cut -c 2-5`
     mv $i `basename $i .jp`.jpg
    done
done

阅读(3985) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~