删除文件时排除特定文件

删除文件时排除特定文件
删除当前目录下所有 *.txt文件,除了test.txt
rm `ls *.txt|egrep -v test.txt`
或者
rm `ls *.txt|awk '{if($0 != "test.txt") print $0}'`
排除多个文件
rm `ls *.txt|egrep -v '(test.txt|fff.txt|ppp.txt)'`
---------------
rm -f `ls *.log.1|egrep -v '(access-2010-09-06.log|error-2010-09-06.log)'`
rm -f `ls *.log|egrep -v '(access-2010-09-06.log|error-2010-09-06.log)'`
---------------
rm -f `ls *.log|egrep -v '(20100906.log)'`
---------------
这里是用ls得到原始数据,也可以用find命令
rm `find . -name *.txt | egrep -v ‘(test.txt|fff.txt|ppp.txt)'`

==========================================
egrep是grep的扩展, egrep除了具备grep的基本功能外还可以使用附加的正则表示式元字符, 如
[a-z]+A
[a-z]?A
[a-z]|[a-z]
abc(d|e)
等, 另外egrep不允许使用\(\)和\{\}

egrep 是 grep的扩展,使用 egrep的主要好处是其在 grep提供的正则表达式元字符集的基础上增加了更多的元字符。不过,egrep 不支持 grep 的\(\)标记匹配字符和\{\}重复的功能。
下表给出了egrep新添的正则表达式元字符 元字符 功能 示例 匹配对象
+ 匹配1个或多个前一字符 ‘[a-z]+ove’ 匹配跟在一或多个小写字母后面的ove。将找出move,love等
? 匹配0个或1个前一字符 ‘lo?ve’ 匹配后面跟一个或不跟字母o的l.将找到love或lve
a|b 匹配a或b ‘love|hate’ 匹配love和hate这两个表达式之一
() 字符组 ‘love(able|ly)(ov)+’ 匹配loveable或lovely加上ov的一次或多次出现

grep、fgrep 和 egrep 命令

grep 命令一次只能搜索一个指定的模式;egrep 命令检索扩展的正则表达式(包括表达 式组和可选项);fgrep 命令检索固定字符串,它不识别正则表达式,是快速搜索命令。

这 组命令在搜索与定位文件中特定的主题方面非常有用。要搜索的模式可以被认为是一 些关键词,您可以用它们来搜索文件中包含的这些关键词。编写程序时,可以用它来寻 找某一个函数,或是相关的词组。grep 命令的搜索功能比 fgrep 强大,因为 grep 命令的搜索模式可以是正则表达式,而 fgrep 却不能。

grep,egrep,fgrep用法

grep (global regular expression print)是一种文本过滤程序,按照正则表达式的规则,筛选出含有指定模式字符串的文本行。

1.作用

grep命令可以指定文件中搜索特定的内容,并将含有这些内容的行标准输出。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。

2.格式

grep [options] PATTERN FILE

3.主要参数

grep [options]
[options]主要参数:
-c:只输出匹配行的计数。
-i:不区分大小写(只适用于单字符)。
-h:查询多文件时不显示文件名。
-l:查询多文件时只输出包含匹配字符的文件名。
-n:显示匹配行及行号。
-s:不显示不存在或无匹配文本的错误信息。
-v:显示不包含匹配文本的所有行。

pattern正则表达式主要参数:
\    忽略正则表达式中特殊字符的原有含义。
^ 匹配正则表达式的开始行。 
$ 匹配正则表达式的结束行。 
< 从匹配正则表达式的行开始。 
> 到匹配正则表达式的行结束。 
[ ] 单个字符集合,如[ABCD]即A,B,C,D任一字符符合要求 。 
[ - ] 范围,如[A-Z],即A、B、C一直到Z都符合要求 。
. 所有的单个字符。 
*    重复字符,长度可以为0。 

正则表达式是Linux/Unix系统中非常重要的概念。正则表达式(也称为“regex”或“regexp”)是一个可以描述一类字符串 的模式(Pattern)。如果一个字符串可以用某个正则表达式来描述,我们就说这个字符和该正则表达式匹配(Match)。这和DOS中用户可以使用通 配符 “*”代表任意字符类似。在Linux系统上,正则表达式通常被用来查找文本的模式,以及对文本执行“搜索-替换”操作和其它功能。

4.应用实例

grep -n _DATE_ *.c 在所有后缀为.c文件中查找含有正则表达式_DATE_的行,并打印行号。

grep -v '[Dd]isable' device.stat>device.active 将文件device.stat中取消所有含有指定模式的行,生成新文件device.active

grep -i richard telnos 在文件telnos中检索字符串richard,不顾字母的大小写。

grep '[0-9]*' chapter1 由于[0-9]*与空字符串匹配,上述命令打印出charpter1文件中所有行,而不是仅打印出含有数字的行。正确的用法是 grep '[0-9][0-9]*' chapter1 或 egrep '[0-9]+' chapter1

查询DNS服务是日常工作之一,这意味着要维护覆盖不同网络的大量IP地址。有时IP地址会超过2000个。如果要查看nnn.nnn网络地址,但 是却忘了第二部分中的其余部分,只知到有两个句点,例如nnn nn..。要抽取其中所有nnn.nnn IP地址,使用[0-9 ]{3 }.[0-0{3}。含义是任意数字出现3次,后跟句点,接着是任意数字出现3次,后跟句点.

$grep '[0-9 ]{3 }.[0-0{3}.' ipfile

ipfile的内容
333.225.332.235 123.456.789.123 234.567.889.235
输出结果
333.225.332.235 123.456.789.123 234.567.889.235

$grep '[0-9 ]{3 }.[0-9{3}.' -c ipfile
输出结果
3
$grep '[0-9 ]{3 }.[0-9{3}.' -l ipfile
输出结果
ipfile
$grep '[0-9 ]{3 }.[0-9{3}.' -n ipfile
输出结果
1:333.225.332.235 2:123.456.789.123 3:234.567.889.235

补充说明,grep家族还包括fgrep和egrep。fgrep是fix grep,允许查找字符串而不是一个模式,运算速度快,适合于从大量数据中进行检索;egrep是扩展grep,支持基本及扩展的正则表达式,可用()及|等,但不支持q模式范围的应用及与之相对应的一些更加规范的模式。

该命令的各选项含义如下:

-E 每个模式作为一个扩展的正则表达式对待。 -F 每个模式作为一组固定字符串对待(以新行分隔),而不作为正则表达式。 -b 在输出的每一行前显示包含匹配字符串的行在文件中的字节偏移量。 -c 只显示匹配行的数量。 -i 比较时不区分大小写。 -h 在查找多个文件时,指示grep不要将文件名加入到输出之前。 -l 显示首次匹配串所在的文件名并用换行符将其隔开。    当在某文件中多次出现匹配串时,不重复显示此文件名。 -n 在输出前加上匹配串所在行的行号(文件首行行号为1)。 -v 只显示不包含匹配串的行。
-x 只显示整行严格匹配的行。 -e expression 指定检索使用的模式。用于防止以“-”开头的模式被解释为命令选项。 -f expfile 从expfile文件中获取要搜索的模式,一个模式占一行。

转载:http://blog.zol.com.cn/2322/article_2321781.html

时间: 2024-10-31 07:40:23

删除文件时排除特定文件的相关文章

win7系统删除文件时提示该文件太大无法放入回收站怎么办

  win7系统删除文件时提示该文件太大无法放入回收站故障图: 解决方法: 1.我们可以将回收站的空间设置的大一点,首先鼠标右击桌面上的回收站选择"属性"选项; 2.在打开的回收站属性界面中,可以看到每一个盘符都有对应的删除文件大小限制,这里我们可以选择自定义回收站大小,然后修改成适合的大小,之后点击确定按钮即可解决.

字符串-网页上传文件时怎么把文件加密后上传

问题描述 网页上传文件时怎么把文件加密后上传 我想在html页面选择一个上传文件,在js获得这个文件的信息,然后对这个文件进行对称加密后再上传.初步想法是把文件是以数据流发到后台再生成一个完整文件的,但怎么获得这个文件的数据流?另一个想法是把先把文件转成字符串,然后加密,再把字符串生成文件2,然后上传,但怎样才能转成字符串并且把加密的字符串转回文件?请大神解答,感激不尽 解决方案 在Web架构中如果要保密, 最简单最安全的方法是使用HTTPS协议. 用js获取文件数据流是可以的, 但需要新版浏览

activex-C#开发ActiveX控件调用dll文件时,dll文件放在什么位置,我的出错了

问题描述 C#开发ActiveX控件调用dll文件时,dll文件放在什么位置,我的出错了 通过c#谢了一个很简单的Activex控件,调用dll文件(dll文件是c++写的,并且dll文件不是com组件),在普通的容器中调用动态库都没问题,但是通过activex时就会出错,请问这是问什么,请留言,也可以加我qq:574225218 解决方案 在dll文件中调用VBA的命令 解决方案二: 是在IE中测试出错么?尝试把浏览器的安全等级设置全部调到最低,在客户端安装.net framework并且运行

kindeditor 上传文件时 怎么让 文件说明 自动生成

问题描述 kindeditor 上传文件时 怎么让 文件说明 自动生成 修改 kindeditor 上传组件 文件说明 默认返回 文件名 这个应该怎么实现 需要修改什么文件 要详细的 谢谢啦 解决方案 http://blog.sina.com.cn/s/blog_533f138e01019re7.html 解决方案二: kindeditor的demo里面有对应的语言,修改语言文件名的生成规则就好了,不过建议还是用时间命令,要不有中文你处理不好编码小心乱码..

用vbs实现在启动 Windows 资源管理器时打开特定文件夹_vbs

my-script.vbs "c:\scripts" 在文件夹路径的两端必须加双引号吗?本例中不需要.但是,如果路径中有空格,则必须加双引号.以下命令行将不起作用: my-script.vbs c:\documents and settings\kmyer 只要是向脚本传递包含空格的参数,就必须将整个参数括在双引号内(否则无需如此).换句话说: my-script.vbs "c:\documents and settings\kmyer" 这就是命令解释程序的工作方

C#读取文件时,判断文件乱码问题

问题描述 请问,通过StreamReaderobjReader=newStreamReader(file.ToString(),UnicodeEncoding.GetEncoding("utf-8"));读取文件如何判断读取的文件里面还有乱码? 解决方案 解决方案二:你已经把他格式成了utf-8了..我觉得是你在读取文件的时候看这个文件是什么格式的也许大神们知道怎么做..呵呵解决方案三:一般的TXT文本用默认就可以了解决方案四:StreamReaderobjReader=newStre

java文件对话框过滤特定文件类型示例_java

思路分析: 因为是窗体应用,首先看视图层.需要一个按钮控件JButton用来选择文件夹:需要一个标签控件JLabel用来显示选择的路径:需要一个标签控件JLabel提示用户输入什么:需要一个文本框控件JTextField供用户输入文件类型:需要一个表格控件JTable显示选中目录下指定类型的文件.对于按钮控件,为其绑定事件处理方法,在该方法中首先创建JFileChooser文件选择器对象,为该对象设置选择器的过滤器,即通过JFileChoose类的setFileSelectionMode()方法

win8.1系统搜索文件时遇到同一个文件重复显示怎么办

  解决方法如下: 1.在控制面板找到索引选项; 2.点击高级; 3.点击重建; 4.点击确定,重建索引选项开始进行.

php上传Excel文件时如何判断文件中有图片

 代码如下 复制代码 $excelPath = 'Test.xls';    $objReader = PHPExcel_IOFactory::createReader('Excel5');  $objReader->setReadDataOnly(true);    $objPHPExcel = $objReader->load($excelPath);  $currentSheet = $objPHPExcel->getActiveSheet();  $AllImages= $cur