在Linux系统中,文件的匹配查询是一个经常需要用到的操作。如果只是简单地查找某个文件或某个目录下的特定文件,使用一些基本的命令就可以满足需求。但是当需要进行高效的多条件匹配时,简单的命令可能就不太够用了。在这种情况下,需要使用一些专门的技巧来实现更高效的查询。
本文将介绍一种实现多条件匹配的方法,即使用两个文件进行匹配。这个方法适用于需要查找满足多个条件的文件的情况,比如查找同时满足文件名、文件大小和文件类型等多个条件的文件。
方法概述
这个方法是通过比较两个文件的内容来实现的。之一个文件是一个列表文件,其中列出了需要匹配的条件,比如文件名、文件大小、文件类型等。第二个文件是需要进行匹配的文件列表,这个列表包含了所有需要进行查询的文件。程序会逐一检查第二个文件列表中的每个文件,看它是否满足之一个文件列表中列出的所有条件。
如果一个文件满足了所有条件,那么它就被认为是匹配成功的。程序会把匹配成功的文件加入到输出文件列表中。输出文件列表中列出了所有匹配成功的文件的路径和文件名。
使用示例
下面是一个使用示例,假设我们需要查找满足以下条件的文件:
– 文件名以“log”结尾
– 文件大小在100KB以上
– 文件类型为普通文件
我们首先需要创建一个包含这些条件的文件列表文件,比如我们把这个文件命名为“conditions.txt”。文件内容如下:
“`
name=log$
size=+100k
type=file
“`
然后我们需要创建一个需要进行匹配的文件列表文件。比如我们把这个文件命名为“filelist.txt”。这个文件包含了所有需要进行查询的文件的路径和文件名。文件内容如下:
“`
/home/user/test/test.log
/home/user/test/test1.log
/home/user/test/test2.jpg
“`
现在我们可以使用下面的命令来进行查询:
“`
find $(cat filelist.txt) -type f -print0 | xargs -0r grep -ilZf conditions.txt | xargs -0r printf ‘%s\n’
“`
这个命令的含义是:
– find $(cat filelist.txt) -type f -print0:根据“filelist.txt”中列出的文件路径和文件名,查找所有类型为普通文件的文件,并将它们的路径和文件名输出到标准输出。
– grep -ilZf conditions.txt:使用“conditions.txt”中列出的条件来匹配通过之一步查找到的文件。可以把这个步骤看作是“筛选”操作,只有满足条件的文件才会被保留下来。
– xargs -0r printf ‘%s\n’:将通过第二步“筛选”得到的所有文件的路径和文件名输出到标准输出。
通过这个命令,我们可以得到所有满足条件的文件的路径和文件名。
方法优势
这个方法相对于其他方法的优势在于它可以高效地实现多条件匹配。使用这个方法可以避免反复地使用一些简单的命令进行搜索和筛选,从而提高查询的效率。这个方法的另一个优势在于它可以轻松地组合不同的条件,满足不同的查询需求。
在Linux系统中,文件的匹配查询是一个常见的操作。通过使用两个文件来实现多条件匹配,可以高效地实现复杂的查询需求。这个方法适用于需要查找满足多个条件的文件的情况,比如查找同时满足文件名、文件大小和文件类型等多个条件的文件。对于需要进行高效查询的情况,这个方法是非常有用的。
成都网站建设公司-创新互联,建站经验丰富以策略为先导10多年以来专注数字化网站建设,提供企业网站建设,高端网站设计,响应式网站制作,设计师量身打造品牌风格,热线:028-86922220sed编辑器是一行一行的处理文件,正在处理的内容存放在模式空间(缓冲区)中,处理完毕后按照选项的规定进行输出或文件的修改。
sed主要用来自动编辑一个或多个文件;简化岁斗文件的反复操作,用于非交互编译文件。
可以使用一个简单的数字,或是一个行号范围
注意:p的动作是:打印匹配行。
1. 原始文件:
2. sed的默认动作
(1)sed的默认动作是打印文件中的所有行。
3. 打印特定行
(1)因为sed命令默认打印文件中所有行。所以第三行会被打印两遍。那如何只打印第三行呢?使用【-n】命令,只打印匹配的行。
(2)使用【-n】命令,只打印匹配到的行
(3)打印行
(4)打印包含模式的行
(5)打印包含模式和指定行号之间的行
(6)包含模式和包含模式之间的行
(7)
{}执行多个命令(command),使用;隔开。=是显示文件行的行号。p是打印匹配行
(8)!取反操作
(9)q命令:之一个模式匹配完成后退出或立即退出,使用该命令打印前5行
(1)使用进行正则匹配
(2)其他的正则表达式
(1)打印出以#开头的行,然后用!进行反选,则表示过滤掉以#开头的行,不会过滤掉空格。
(2)匹配以#开头的行,进行取反,则打印出非#开头的行,然后其结果在对空格开头的行进行取反。即
过滤掉以#开头的行和以空格开头的行。
{}表示在定位行执行的命令组。
(3)sed支持对单个文件实现不同的操作,每个操作用-e参数。定位到执行的行后,使用d命令,直接删除匹配到的行。
需要注意的是,对源文件的添加要使用【-i】参数。
s:使用替换模式替换相应模式
(1)在匹配行前面替换字符,使用【s】命令。
(2)在所有行开头替换元素【s】
(3)在所有行的末尾替换元素
(4)指定行,进行替换操作
(5)【&】符号代表的是匹配到的字符。在匹配到字符后,可以使用&代替。
(6)在匹配到行前面添加一行,使用【i】的命令
(7)在匹配行的后面添加一行,使用【a】命令
(8)当添加多行时,使用\n来转义
(9)@代表的是【地址定界符】,一般由三个组成,坦雀散定让氏界符可以是/,$,#等特殊字符,此命令表示,匹配特定字符的行进行替换。
(10)使用命令【g】修改全文中出现的匹配字符。
(11)若后面接数字之后在接g,表示匹配的行中,第几次出现。就替换,2g表示替换行中第二次出现。
(1)删除以非#号开头的行,即显示以#号开头的行。
(2)删除之一行
(3)删除最后一行
(4)删除指定的行区间
(5)删除包含特定单词的行
本文参考:
1、最强大的搜索命令:find 查找各种文件的命令
2、在文件资料中查找文件:locate
3、搜索命令所在的目录及别名信息:which
4、搜索命令所在的目录及帮助文档路径:whereis
5、在文件中搜寻
字符串
匹配的行并输出:grep
6、分页显示一个文件或任何输出结果:more
7、分页显示一个文件并且可以回头:less
8、指定显示前多少行文件内容:head
9、指定显示文件后多少行内容:tail
10、查看一个文件:cat
11、查看文件内容多少字符多少行多少字节:wc
12、排序文件内容:sort
一、根据 文件或目录名称 搜索
find 【搜索目录】【-name或者-iname】【搜索字符】:-name和-iname的区别一个区分大小写,一个不区分大小写
eg:在/etc 目录下搜索名字为init的文件或目录
①、find /etc -name init (精准搜索,名字必须为 init 才能搜索的到)
②、find /etc -iname init (精准搜索,名字必须为 init或者有字母大写也能搜索的到)
③、find /etc -name *init (模糊搜索,以 init 结尾的文件或目录名)
④、find /etc -name init??? (模糊搜索,? 表示单个字符,即搜索到 init___)
二、根据 文件大小 搜索
eg:在
根目录
下查找大于 100M 的文件
find / -size +202300
这里 +n 表示大于,-n 表示小于,n 表示等于
1 数据块 == 512 字节 0.5KB,也就是1KB等于2数据块
100MB ==KB202300数据块
三、根据 所有者和所属组 搜索
①、在home目录下查询所属组为 root 的文件
find /home -group root
②、在home目录下查询所有者为 root 的文件
find /home -user root
四、根据 时间属性 搜索
find 【路径】【选项】【时间】
选项有下面三种:-amin 访问时间
cmin 文件属性被更改
mmin 文件内容被修改
时间:蚂唤+n,-n,n分别表示超过n分钟,n分钟以内和n分钟
eg:在 /etc 目录下查找5 分钟内被修改过属性的文件和目录
find /etc -cmin -5
五、根据
文件类型
或i节点 搜索
-type 根据文件类型查找:
f表示文件,d表示目录,l表示软链接
eg:查找 /home 目录下文件类型是目录的
find /home -type d
-inum 根据i节点查找
eg:查找 /tmp 目录下i节点为400342的文件或目录
find /tmp -inum
六、组轿烂合条件 搜索
这里有两个参数:
①、-a 表示两个条件同时满足(and)
②、-o 表示两个条件满足任意一个即可(or)
范例:查找/etc目录下大闷帆凯于80MB同时小于100MB的文件
find /etc -size +a -size
语法:locate【文件名】 -i 不区分大小写
注意:这里和 find 命令是有区别的,find是全盘检索,而locate 是在文件资料库中进行搜索。所以locate命令的执行要比find命令执行速度快很多。但是这里有个问题,文件资料库是需要不断更新的。我们新创建的文件如果不更新 文件资料库,使用 locate 是查找不到的。
updatedb 手动更新资料库,但是对于/tmp目录下的新建文件,是更新不到文件资料库的,因为/tmp目录不属于文件资料库的收录范围。
eg:locate hcf
功能描述:搜索命令所在的目录及别名信息
语法:which【命令】
eg:which ls
功能描述:搜索命令所在的目录及帮助文档路径
语法:whereis【命令】
eg:whereis ls
功能描述:在文件中搜寻字符串匹配的行并输出
语法:grep -iv 【指定字符串】【文件】
i 不区分大小写
v 排除指定字符串
eg:查找 /root/install.log 文件中包含 mysql 字符串的行,并输出
grep mysql /root/install.log
本搜索工具,根据用户指定的模式,对目标文件逐行进行匹配检查,打印匹配到的行
grep是在文件中搜索匹配的字符串,是在文件中进行内容搜索,这个命令后面用到的比较多
描述:
分页显示一个文件或任何输出结果
用于查看纯文本文件(较长的)格式
格式:
more 文件
less 与 more 类似,但使用 less 可以随意浏览文件,而 more 仅能向前移动,却不能向后移动,而且 less 在查看之前不会加载整个文件。
head
用于显示指定文件开始多少行内容
命令参数:
-n 10 显示前10行
-n -10 正常输出但不显示最后的10行
eg:显示new.txt的前两行内容
head -n 2 new.txt
head -2 new.txt
tail
用于显示指定文件末尾多少行内容
命令参数:
-n 10 显示后面10行
-f 持续刷新显示的内容
eg:显示new.txt的末尾两行内容
tail -n 2 new.txt
tail -2 new.txt
eg:指定从第二行开始显示
tail -n +2 new.txt
描述:一次显示整个文件内容
cat 命令 用于查看纯文本文件(较短)
cat …
描述:wc 命令默认情况下会打印
换行符
数、单词数和字符数。
用法:wc
用法:sort
关于两个文件多条件匹配linux的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
成都创新互联科技公司主营:网站设计、网站建设、小程序制作、成都软件开发、网页设计、微信开发、成都小程序开发、网站制作、网站开发等业务,是专业的成都做小程序公司、成都网站建设公司、成都做网站的公司。创新互联公司集小程序制作创意,网站制作策划,画册、网页、VI设计,网站、软件、微信、小程序开发于一体。
新闻标题:Linux实现多条件匹配:两个文件的高效查询技巧(两个文件多条件匹配linux)
网站链接:http://www.shufengxianlan.com/qtweb/news42/333742.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联