linux 匹配?Linux软件大全

大家好,关于linux 匹配很多朋友都还不太明白,不过没关系,因为今天小编就来为大家分享关于Linux软件大全的知识点,相信应该可以解决大家的一些困惑和问题,如果碰巧可以解决您的问题,还望关注下本站哦,希望对各位有所帮助!

Linux中匹配字符串的简单方法linux匹配某个字符串

Linux是由内核和多个应用组成的开源操作系统,在开发时,我们经常需要用到字符串的匹配方法来实现程序的某些功能。Linux中自带的命令行工具及其可以十分方便地对字符串进行查找和匹配,如果要在程序中使用Linux中匹配字符串的简单方法,那么下面介绍几种最简单的实现方式。

第一种方法是使用grep命令来匹配字符串,这是Linux中最常用的字符串匹配方式,它的语法为 grep [option] pattern file,用法如下:

例如:

$ grep“hello” test.txt

此命令用于在文本文件test.txt中查找所有出现“hello”这个字符串的行,如果存在此字符串,此命令会输出查找的结果。

第二种方法是使用sed命令,sed语法为 sed [option]‘s/pattern/replacement/’ file,用法如下:

例如:

$ sed‘s/hello/world/’ test.txt

此命令用于将文本文件test.txt中所有出现“hello”字符串替换为“world”字符串,如果应用成功,会输出最终结果。

第三种方法是使用awk命令,这也是Linux中比较常用的命令,最常用的用法是按照某个关键字进行选择和匹配,语法为 awk [option]‘pattern{action}’ file,如下:

例如:

$ awk‘/hello/{print$1}’ test.txt

此命令用于查找文本文件test.txt中出现“hello”字符串的所有行,并且输出出现的字符的第一个字段,如果匹配成功,会输出最终的结果。

以上就是简单介绍Linux中匹配字符串的几种简单方法,它们的使用都十分方便,有效重用的方法,在实际的开发中可以大大减少文件内字符串处理的时间及其有效性。

Linux中vi的查找、替换、删除操作

vi查找替换命令详解

一、查找查找命令/patternEnter:向下查找pattern匹配字符串?patternEnter:向上查找pattern匹配字符串使用了查找命令之后,使用如下两个键快速查找:n:按照同一方向继续查找N:按照反方向查找字符串匹配pattern是需要匹配的字符串,例如:

1:/abcEnter  #查找abc2:/ abc Enter #查找abc单词(注意前后的空格)

除此之外,pattern还可以使用一些特殊字符,包括(/、^、$、*、.),其中前三个这两个是vi与vim通用的,“/”为转义字符。

1:/^abcEnter #查找以abc开始的行 2:/test$Enter #查找以abc结束的行 3://^testEnter #查找^tabc字符串

二、替换基本替换

1::s/vivian/sky/    #替换当前行第一个 vivian为 sky2::s/vivian/sky/g  #替换当前行所有 vivian为 sky3::n,$s/vivian/sky/  #替换第 n行开始到最后一行中每一行的第一个 vivian为 sky4::n,$s/vivian/sky/g  #替换第 n行开始到最后一行中每一行所有 vivian为 sky5:(n为数字,若 n为.,表示从当前行开始到最后一行)6: 7::%s/vivian/sky/   #(等同于:g/vivian/s//sky/)替换每一行的第一个 vivian为 sky8::%s/vivian/sky/g #(等同于:g/vivian/s//sky/g)替换每一行中所有 vivian为 sky

可以使用#或+作为分隔符,此时中间出现的/不会作为分隔符

1::s#vivian/#sky/#    替换当前行第一个 vivian/为 sky/2::%s+/oradata/apras/+/user01/apras1+(3:使用+来替换/):/oradata/apras/替换成/user01/apras1/

删除文本中的^M问题描述:对于换行,window下用回车换行(0A0D)来表示,linux下是回车(0A)来表示。这样,将window上的文件拷到unix上用时,总会有个^M,请写个用在unix下的过滤windows文件的换行符(0D)的shell或c程序。使用命令:cat filename1| tr-d“^V^M” newfile;使用命令:sed-e“s/^V^M//” filename outputfilename需要注意的是在1、2两种方法中,^V和^M指的是Ctrl+V和Ctrl+M。你必须要手工进行输入,而不是粘贴。在vi中处理:首先使用vi打开文件,然后按ESC键,接着输入命令:

1::%s/^V^M//2::%s/^M$//g

如果上述方法无用,则正确的解决办法是:

1: tr-d“/r” src dest2: tr-d“/015″ dest3: 4: strings AB

其它用法

1::s/str1/str2/    #用字符串 str2替换行中首次出现的字符串 str12::s/str1/str2/g    #用字符串 str2替换行中所有出现的字符串 str13::.,$ s/str1/str2/g  #用字符串 str2替换正文当前行到末尾所有出现的字符串 str14::1,$ s/str1/str2/g  #用字符串 str2替换正文中所有出现的字符串 str15::g/str1/s//str2/g  #功能同上

从上述替换命令可以看到:g放在命令末尾,表示对指定行的搜索字符串的每次出现进行替换;不加 g,表示只对指定行的搜索字符串的首次出现进行替换;g放在命令开头,表示对正文中所有包含搜索字符串的行进行替换操作。也就是说命令的开始可以添加影响的行,如果为g表示对所有行;命令的结尾可以使用g来表示是否对每一行的所有字符串都有影响。三、简单的vim正则表达式规则在vim中有四种表达式规则:magic(/m):除了$.*^之外其他元字符都要加反斜杠nomagic(/M):除了$^之外其他元字符都要加反斜杠/v(即 very magic之意):任何元字符都不用加反斜杠/V(即 very nomagic之意):任何元字符都必须加反斜杠vim默认使用magic设置,这个设置也可以在正则表达式中通过/m/M/v/V开关临时切换。例如:

1://m.*    #查找任意字符串2://M.*    #查找字符串.*(点号后面跟个星号)3: 4://v(a.c){3}$ #查找行尾的abcaccadc5://m(a.c){3}$ #查找行尾的(abc){3}6://M(a.c){3}$ #查找行尾的(a.c){3}7://V(a.c){3}$ #查找任意位置的(a.c){3}$

推荐使用默认的magic设置,在这种情况下,常用的匹配有:

1://abc    #查找以test开始的字符串 2:/abc/    #查找以test结束的字符串 3: 4:$   匹配一行的结束 5: ^   匹配一行的开始 6:/  匹配一个单词的开始,例如//abcEnter:查找以abc开始的字符串 7:/  匹配一个单词的结束,例如/abc/Enter:查找以abc结束的字符串 8: 9:*   匹配0或多次10:/+  匹配1或多次11:/=  匹配0或1次12: 13:.   匹配除换行符以外任意字符 14:/a  匹配一个字符15:/d  匹配任一数字  16:/u  匹配任一大写字母17: 18: []  匹配范围,如t[abcd]s匹配tas tbs tcs tds19:/{}  重复次数,如a/{3,5}匹配3~5个a20:/(/) 定义重复组,如a/(xy/)b匹配ab axyb axyxyb axyxyxyb...21:/|  或,如:for/|bar表示匹配for或者bar22: 23:/%20c 匹配第20列24:/%20l 匹配第20行

vi+文件名,可以创建一个文件

用cat+问价名,可以查看一个文件

用cut-f3+文件名,可以选择文件中的第3段字符

输入英文的冒号:然后输入wq可以保存文件内容并退出

输入英文的冒号:然后输入q可以放弃保存并退出

输入英文的冒号/然后输入一个字符串,可以查找该字符串

如果以上经验帮到您,麻烦在左下角给点个赞,谢谢!

详解Linux中查找目录和文件的find和locate命令

find

find路径-命令参数 [输出形式]

参数说明:

路径:告诉find在哪儿去找你要的东西,

命令参数:参数很多下面会说到

输出形式:输出形式很多,-print,-printf,-print0,-exec,-ok,-ls反正很多自己看手册吧。

说一下exec,

-exec find命令对匹配的文件执行该参数所给出的其他linux命令。相应命令的形式为'命令- and'{};,注意{}和;之间的空格。

-ok和- exec的作用相同,只不过和会人交互而已,OK执行前会向你确认是不是要执行。

find命令主要参数:

-name按照文件名查找文件。

-perm按照文件权限来查找文件。

-prune使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用了- depth选项,那么-prune选项将被find命令忽略。

-user按照文件属主来查找文件。

-group按照文件所属的组来查找文件。

-mtime-n+n按照文件的更改时间来查找文件,-n表示文件更改时间距现在n天以内,+n表示文件更改时间距现在n天以前。find命令还有-atime和-ctime选项,但它们都和-mtime选项

相似,所以我们在这里只介绍-mtime选项。

-nogroup查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。

-nouser查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。

-newer file1! file2查找更改时间比文件file1新但比文件file2旧的文件。

-type查找某一类型的文件,诸如:

b-块设备文件。

d-目录。

c-字符设备文件。

p-管道文件。

l-符号链接文件。

f-普通文件。

s- socket文件

-size n[c]查找文件长度为n块的文件,带有c时表示文件长度以字节计。

-depth在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。

-maxdepth查找最大目录层数如 1,即只查找一层目录

-fstype查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件

/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息。

-mount在查找文件时不跨越文件系统mount点。

-follow如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。

-cpio对匹配的文件使用cpio命令,将这些文件备份到磁带设备中。

例:

a,通过名字来查找

代码如下:

[zhangy@BlackGhost~]$ find~-name memcached.pid-print#查找home目录下文件名为memcache.pid的文件

/home/zhangy/memcached/memcached.pid

[zhangy@BlackGhost~]$ find.-name"*.pid"-print#.代表当前目录,查找所有以pid结尾的文件

./memcached/memcached.pid

./.tencent/qq/95219454.pid

[zhangy@BlackGhost~]$ find~-name"[0-9]*.pid"-print#查找以数字开头的所有pid文件,在这里要说[0-9]*不能匹配23,它跟一般的语言类正则不太一样,shell里面的*可以代表一切字符(单个,多个都行),如果想匹配2345只能这样写[0-9][0-9][0-9][0-9]

/home/zhangy/.tencent/qq/95219454.pid

[zhangy@BlackGhost~]$ find/home/zhangy/.tencent/-name"[0-9]*.pid"-print#在.tencent文件夹下面找pid文件

/home/zhangy/.tencent/qq/95219454.pid

b,通过文件权限来查找

代码如下:

[zhangy@BlackGhost css]$ find~-perm 755-print|more#~代表的是$home目录,查找权限为755的文件

/home/zhangy/www/css2/c_textshadow.html

/home/zhangy/www/css2/c_textautospace.html

[zhangy@BlackGhost css]$ find.-perm 700-name"u_*"-print|more#查找所有以产u_开头的,并且权限为700的文件

./css2/u_length_cm.html

./css2/u_length_px.html

c,prune来忽略目录来查找

代码如下:

[zhangy@BlackGhost download]$ find.-name"*.gz"-prune-o(!-name aaa)-print#查找在前目录中,不在以aaa结尾的目录中的,不以gz结尾的文件

.

./eaccelerator-0.9.5.3.tar

./fix-crash-in-excerpts.patch

./AddFeed_Widget_WordPress_Plugin.zip

./jQuery china-addthis plugin 1.07.rar

d,根据文件类型来查找文件

代码如下:

[zhangy@BlackGhost download]$ find.-type d-print#查找当前目录下面的目录

.

./ddd

[zhangy@BlackGhost download]$ find.!-type d-print#找当前目录下面的非目录文件

./eaccelerator-0.9.5.3.tar

./haproxy-1.3.15.7.tar.gz

./fix-crash-in-excerpts.patch

e,根据文件所属用户和用户组来找文件

代码如下:

[zhangy@BlackGhost download]$ find.-nouser-print#查找当前目录中,没有归属的文件

[zhangy@BlackGhost download]$ find/home/zhangy/download-user zhangy-group users-print#查找用户组为users,所属用户为zhangy的文件

/home/zhangy/download

/home/zhangy/download/eaccelerator-0.9.5.3.tar

/home/zhangy/download/haproxy-1.3.15.7.tar.gz

f,根文件大小来查找

代码如下:

[zhangy@BlackGhost download]$ find/home/zhangy/download-size+1000000c-print#查找文件大小大于1000000字符的文件,注意+号表示大于

/home/zhangy/download/eaccelerator-0.9.5.3.tar

/home/zhangy/download/mmseg-0.7.3.tar.gz

[zhangy@BlackGhost download]$ find/home/zhangy/download-size-10-print#查找文件大小小于10块的文件,注意-号表示小于,一块等于512b

/home/zhangy/download

/home/zhangy/download/fix-crash-in-excerpts.patch

/home/zhangy/download/test.sql.zip

g,根文件的修改时间来查找

代码如下:

[zhangy@BlackGhost download]$ find/home/zhangy-mtime-5-print#5天修改过的文件,-表示以内

/home/zhangy/www/css2/c_textshadow.html

/home/zhangy/www/css2/c_textautospace.html

[zhangy@BlackGhost download]$ find/home/zhangy-mtime+5-print#查找5天前修改过的文件,+表示以前

/home/zhangy/www/test.php

[root@vmx14420 www]# find./-mmin-5-print#查找5分钟以内修改过的文件

./cache/index.html

h,exec解释

代码如下:

[zhangy@BlackGhost download]$ find.-type f-size+1000000c-exec ls-al{};#显示当前目录下面所有大于1000000的文件,exec后面执行了一个命令,{}这个代表文件名

-rw-r--r-- 1 zhangy users 3624960 2009-03-08./eaccelerator-0.9.5.3.tar

-rw-r--r-- 1 zhangy users 3091711 12-18 13:48./mmseg-0.7.3.tar.gz

-rw-r--r-- 1 zhangy users 1191330 2009-06-26./pcre-7.9.tar.gz

i,匹配

代码如下:

[tank@localhost workspace]$ find./database/-name'*.sql'-print#查找以sql结尾的文件

./database/28toplearning.sql

[tank@localhost workspace]$ find./database/-name'*.sql*'-print#查找文件名包括sql文件

./database/28toplearning.sql

[tank@localhost workspace]$ find./database/-name'28*'-print#查找以28开头的文件

./database/28toplearning.sql

locate

用法: locate [OPTION]... [PATTERN]...

在mlocate数据库中搜索条目.

-b,--basename匹配唯一的路径名称的基本文件名

-c,--count只显示找到条目的号码

-d,--database DBPATH用 DBPATH替代默认的数据库(/var/lib/mlocate/mlocate.db)

-e,--existing只显示当前存在的文件条目

-L,--follow当文件存在时跟随蔓延的符号链接(默认)

-h,--help显示本帮助

-i,--ignore-case匹配模式时忽略大小写区别

-l,--limit,-n LIMIT限制为 LIMIT项目的输出(或计数)

-m,--mmap忽略向后兼容性

-P,--nofollow,-H当检查文件时不跟随蔓延的符号链接

-0,--null输出时以 NUL分隔项目

-S,--statistics不搜索项目,显示有关每个已用数据库的统计信息

-q,--quiet不报告关于读取数据库的错误消息

-r,--regexp REGEXP搜索基本正则表达式 REGEXP来代替模式

--regex模式是扩展正则表达式

-s,--stdio忽略向后兼容性

-V,--version显示版本信息

-w,--wholename匹配完整路径名(默认)

例:

代码如下:

[root@localhost~]# locate~/install#查找当前目录下以install开头的文件

/root/install.log

/root/install.log.syslog

[root@localhost~]# locate-i~/install#查找当前目录下以install开头的文件,不区分大小写

/root/install.log

/root/install.log.syslog

[root@localhost~]# locate-i/etc/fuc#查找/etc目录下面以fuc开头的文件,不区分大小写

阅读剩余
THE END