当前位置: 首页 > article >正文

find 查找文件grep匹配数据

一、find介绍

1. find . -iname "*.txt"查找当前目录下各个文件夹下的txt属性的文件(i忽略大小写)。

2.find . -type f 查找当前目录下各个文件夹下的文件

3.find . -type d 查找当前目录下各个文件夹下的目录

4.find . -type f | xargs grep -ain -E "匹配字段" --colo=auto

 grep参数介绍-a 选项:以文本文件的形式处理二进制文件,-i 选项:让搜索忽略大小写,-n 选项:在输出结果时,显示匹配行的行号,-E正则匹配,--colo=auto匹配结果自带颜色。

5.find -L ./ -path ./qt-creator-opensource-src-12.0.0/bin -prune -o -path ./qt-creator-opensource-src-12.0.0/coin -prune  -o -type f| xargs grep -ain -E "chen3feng" --color=auto

执行命令所在目录有目录qt-creator-opensource-src-12.0.0。

-path ./qt-creator-opensource-src-12.0.0/bin -prune

  • path 选项用于匹配文件路径,./qt-creator-opensource-src-12.0.0/bin -prune 就是要匹配的路径模式。这意味着只要遇到路径是 ./qt-creator-opensource-src-12.0.0/bin -prune 的目录,find 就会停止对它及其子目录的搜索。
  • -prune 选项是告诉 find 命令,对匹配 -path 条件的目录不要进行遍历,也就是 “修剪” 掉这部分目录树,避免在指定目录及其子目录中继续查找,以此提高查找效率。在这个例子里,./qt-creator-opensource-src-12.0.0/bin -prune 目录及其内部的所有文件和子目录都会被跳过

-o:这是一个逻辑运算符,代表 “或(or)” 的关系,连接前后两个查找条件

-path ./qt-creator-opensource-src-12.0.0/coin -prune

同之前的命令一样含义。

-type f-type 用于指定查找文件的类型,f 表示普通文件(file),也就是查找除了被 -prune 修剪掉的./qt-creator-opensource-src-12.0.0/bin 和 ./qt-creator-opensource-src-12.0.0/coin目录及其子目录之外的所有普通文件。

整体目录结构如下图:

6.find . -type f  \( -name "*json" -o -iname "*lists.txt" \) | xargs grep -ain "匹配项"

find 命令用于在当前目录(.)及其子目录下查找特定类型的文件并进行grep匹配。

  • 括号:括号\(`和`\)用于将多个条件组合在一起,让它们作为一个整体来处理,形成更复杂的逻辑判断。因为括号在 shell 中有特殊意义,所以需要用反斜杠\转义,使其被当作普通字符传递给 find 命令。
  • -name "*json"-name 选项用于按文件名精确匹配,* 是通配符,代表任意字符序列,所以*json会匹配所有以.json为后缀的文件名。
  • -o:这是逻辑运算符 “或(or)”,连接前后两个文件名匹配条件。
  • -iname "*lists.txt"-iname 选项与 -name 类似,也是匹配文件名,但 -iname 是忽略大小写的,所以它会匹配所有名字是*lists.txt的文件,无论大小写如何


http://www.kler.cn/a/472729.html

相关文章:

  • Electron快速入门——跨平台桌面端应用开发框架
  • 接口测试-postman(使用postman测试接口笔记)
  • 根据docker file 编译镜像
  • Jenkins内修改allure报告名称
  • 计算机网络基础——网络协议
  • 将txt转成excel正则化公式的调整
  • 【Altium】AD使用智能粘贴功能把多个网络标签改成端口
  • Erlang语言的字符串处理
  • Visual CoT:解锁视觉链式思维推理的潜能
  • nginx 日志规范化意义及实现!
  • 【江协STM32】10-2/3 MPU6050简介、软件I2C读写MPU6050
  • PHP MySQL 读取数据
  • canal同步es,sql注意事项
  • WJsoft-D-Security数据仿泄露系统(DLP)存在任意文件读取漏洞
  • Linux存储管理之核心秘密(The Core Secret of Linux Storage Management)
  • ios越狱脚本巨魔商店安装教程
  • 【Java 学习】对象赋值的艺术:Java中clone方法的浅拷贝与深拷贝解析,教你如何在Java中实现完美复制
  • 【超详细】MIT 液态神经网络(LNNs)——深度学习新动向
  • ubuntu18升级至ubuntu20
  • wps宏js接入AI功能和接入翻译功能
  • Aviatrix Controller 未授权命令注入漏洞复现(CVE-2024-50603)
  • JAVA XXE 学习总结
  • C 语言奇幻之旅 - 第16篇:C 语言项目实战
  • 安装 华三云实验室 H3C Cloud Lab
  • Android Studio 安装配置(个人笔记)
  • 【杂记】机器视觉 #opencv #numpy #matplotlib