在Linux命令行中,字符串匹配某一行是一项非常重要的功能。随着我们在Linux系统上的工作量增加,我们需要在日常工作中频繁地检索一些文本文件,以找到我们需要的信息。
在这篇文章中,我们将讨论一些常用的Linux命令,这些命令可以帮助我们快速地在文本文件中查找某个字符串。我们将介绍的命令包括grep、sed和awk。
grep命令
grep命令是一种常用的查找命令,它可以在一个或多个文本文件中查找指定的字符串。grep命令的语法如下:
grep [options] pattern [file(s)]
其中,pattern是要查找的字符串,file(s)是要查找的文件。如果不指定文件名,那么grep会从标准输入中读取数据。下面是一些常用的grep选项:
-i:忽略大小写
-v:反向选择,只输出没有匹配到的行
-c:只输出匹配到的行数
例如,假设我们有一个名为file1.txt的文件,文件中包含以下文本:
Hello world!
This is a test file.
Welcome to Linux!
我们可以使用grep命令查找包含“Welcome”单词的行,命令如下:
grep Welcome file1.txt
输出结果如下:
Welcome to Linux!
我们还可以使用-i选项进行大小写不敏感的查找:
grep -i welcome file1.txt
输出结果仍然是:
Welcome to Linux!
sed命令
sed命令是一个非常强大的文本处理工具,它可以对文本文件进行编辑和转换。在字符串匹配方面,sed命令通常用于替换文本文件中的某些字符串。sed命令的语法如下:
sed [options] ‘pattern’ [file(s)]
其中,pattern是要替换的字符串。下面是一些常用的sed选项:
-i:直接修改原始文件
-e:可以使用多个替换操作
-n:只显示替换后的文本
例如,假设我们有一个名为file2.txt的文件,文件中包含以下文本:
Hello world!
This is a test file.
Welcome to Linux!
我们可以使用sed命令将文本文件中的所有“test”字符串替换为“trial”:
sed -i ‘s/test/trial/g’ file2.txt
执行该命令后,file2.txt的内容将变为:
Hello world!
This is a trial file.
Welcome to Linux!
awk命令
awk命令是一种用于处理文本数据的编程语言,它可以对文本文件进行分析和转换。awk的主要功能是在文本文件的每一行中查找并处理某个特定的模式。awk命令的语法如下:
awk [options] ‘{action}’ [file(s)]
其中,action是一个或多个命令,用于指定要操作的文本。下面是一些常用的awk选项:
-F:用于指定模式的分隔符
-v:用于传递变量的值到awk脚本中
例如,假设我们有一个名为file3.txt的文件,文件中包含以下文本:
1 2
5 6
a b
我们可以使用awk命令查找所有以“a”开头的行,命令如下:
awk ‘/^a/ {print}’ file3.txt
输出结果如下:
a b
我们还可以使用awk命令进行更复杂的文本处理。例如,假设我们有一个名为file4.txt的文件,文件中包含以下文本:
name,age,gender
John,25,Male
Jane,30,Female
Chris,28,Male
我们可以使用awk命令计算该文件中的所有年龄的总和,命令如下:
awk -F’,’ ‘NR > 1 {sum += $2} END {print sum}’ file4.txt
输出结果为:
结论
在Linux命令行中使用字符串匹配某一行是一种非常有用的技能。不论是从一个日志文件中查找特定的IP地址,还是从一个包含用户信息的文本文件中搜索年龄大于30岁的用户,都有很多的场景可以应用这项技能。在这篇文章中,我们介绍了grep、sed和awk这三个常用的Linux命令,这些命令可以让我们在文本文件中快速地定位字符串并对其进行操作。当然,这只是这些命令的简单演示,它们还有更多的用法和选项,需要我们进一步深入学习和掌握。
相关问题拓展阅读:
#include
#include
#include
//三个头文件,分别表示标准化io,标准化库文件,字符串类文件的头文件
int main()
{
int line=0;//记录行数
FILE *fp;//定义文件指针
char FILENAME,li,indata,*sust=NULL;//
printf(“Input file name please:”);
gets(FILENAME);//获取文件名
if ((fp=fopen(FILENAME,”r”))!=NULL){//如果读取成功,即fopen函数返回值不为空
printf(“Input a string please:”);
gets(indata);//输入要寻找的那个字符串
while (!feof(fp))//当文件未结束一直执行该操作
{
line++;//行计数加一
fgets(li,255,fp);//读取255个字符
sust=strstr(li,indata);//从字符串li中寻找indata之一次出现的位置(不比较结束符NULL)。参看//
if (sust!=NULL) {//如果未找到
printf(“Found it in line %d\n”,line);
}
}
fclose(fp);//关闭文件
}
else puts(“File not found!”);//文件未找到
return 0;
}
查找目录下的所有文件中是否含有某个字符串
find .|xargs grep -ri “IBM”
查找目录下的所有文件中是否含有某个字符串,并且只打印出文件名
find .|xargs grep -ri “IBM” -l
推荐使用正则表达式
(1)正则表达式一般用来描述文本模式的特殊用法,由普通字符(例如字符a-z)以及特殊字符(称为元字符,如/、*、?等)组成。
(2)基本元字符集及其含义
^ :只匹配行首。 如^a 匹配以a开头的行abc,a2e,a12,aaa,……
$ :只匹配行尾。 如^a 匹配以a结尾的行bca,12a,aaa,…….
* :匹配0个或多个此单字符。 如(a)* 匹配 空,a,aa,aaa,….
:只匹配内字符。可以是一个单字符,也可以是字符序列,用”,”将里面要匹配的不同字符串分开。也可以使用-来表示内字符序列的范围,如表示
\ :只用来屏蔽一个元字符的特殊含义。 如\*,\’,\”,\|,\+,\^,\. 等
.:(点)只匹配任意单字符。
pattern\{n\}:只用来匹配前面pattern出现的次数.n为次数。如a\{2\}匹配aa.
pattern\{n,\}:含义同上,但次数最少为n.如a\{2,\}匹配aa,aaa,aaaa,…..
pattern\{n,m\}:含义同上,但次数在n和m之间。如a\{2,4\}匹配aa,aaa,aaaa三个
(3)举例说明:
^$ :匹配空行
^.$ :匹配包含一个字符的行
\*\.pas :匹配以*.pas结尾的所有字符或文件
或 :假定要匹配任意一个数字
:任意小写字母
:任意大小写字母
:匹配大小写S
\{3\}\.\{3\}\.\{3\}\.\{3\} :匹配IP地址 \{3\}三个0-9组成的字符串;\. :匹配点(注意这里点是特殊的字符,所以要用”\”来屏蔽其含义)
可以试试 \ 转义符
例子:
需求:要在test.log中匹配”respCode”:”00″,注意这里面包含”特殊符号,不包含:
只要输入以下指令即可
grep ‘\”respCode\”:\”00\”‘ test.log
1. 试试用”\”进行转义:
grep “aaa\/fz\|\\u963f\\u72f8\$” yourfile
2. 试试用awk,这个忘了是否需要转义,你自己试试:
sed命令行格式:sed ‘command’ file(s)
options常用选项:
-n或–quiet或——silent:仅显示script处理后的结果;
-e:以选项中的指定的script来处理输入的文本文件;
-f:以选项中指定的script文件来处理输入的文本文件;
-r∶sed 的动作支援的是延伸型正规表示法的语法;
-i∶直接修改读取的档案内容,而不是由萤幕输出;
-h或–help:显示帮助;
-V或–version:显示版本信息。
Command常用命令:
a:新增,a 的后面可以接字符串,而这些字符串会在新的一行出现(目前的下一行);
c:取代,c 的后面可以接字符串,脊雀御这些字符串可以取代 n1,n2 之间的行;
d:删除,d 后面通常不接任何字符串;
i:插入,i 的樱岩后面可以接字符串,而这些字符串会在新的一行出现(目前的上一行);
p:列印,亦即将某个选择的资料印出。通常 p 会与参数 sed -n 一起运作;
s:取代,可以直接进行取代的工作,通常与正规表达式搭配使用。
实例说明:
新增操作:a命令
sed ‘/^bird/a\test’ file将test追加到 以bird开头的行后面
删除操作:d命令
sed ‘/^$/d’ file #删除空白行;
sed ‘2d’ file #删除第二行;
sed ‘2,$d’ file #删除第2行到最后一行;
sed ‘$d’ file #删除最后一行;
sed ‘/^bird/’d file #删除所有开头是bird的行;
插入操作:i命令
sed -i ‘3i\bird ‘ bird.conf #在bird.conf文件第3行之前插入bird
替换文本中的字符串:s命令
sed ‘s/bird/birds/’ file #将文本中的bird替换成birds;
sed -i ‘s/ bird / birds /g’ file #将file文件中每一行的之一个bird替换岁返为birds;
一、基本正则列表与扩展正则
二、sed 文本处理工具的用法介绍
三、认识sed工具的 n、r、i 选项指令
四、认识sed工具的 p、d、s 条件指令
五、认识sed工具的 i、a、c 条件指令
六、认识sed高级应用 r、w 条件指令
七、综合案例
Linux sed
Stream EDitor,流式编辑器
一、基本正则列表与扩展正则
根据推出时间的不同,分为基本正则和扩展正则,扩展正则在基本正则的基础上做了一些优化和新增了一些正则表达符号,因为一些命令没有及时更新,所以你可能会遇到有些命令只支持基本正则,不支持扩展正则,或者需要添加一些支持扩展正则的选项。
关于正则与扩展正则区别的详细介侍伍孝绍可以看我另一篇shell 正则的介绍
基本正则列表
扩展正则列表
二、sed 文本处理工具的用法介绍:
相关说明如下:
sed命令的常用选项如下:
sed命令常用条件指令如下
三、认识sed工具的 n、r、i 选项指令
# sed ‘条件指令’ 文件.. ..
上面的条件指令 我们可以拆分为
# sed ‘范围界定+操作指令’ 文件.. ..
的格式这样更容易理解
sed命令可以使用行号或正则做为条件匹配:
1)sed命令的 -n 选项
执行p打印等过滤操作时,希望看到的是符合条件老稿的文本。但不使用任何选项时,默认会将原始文本一并输出,从而干扰过滤效果。比如,尝试用sed输出/etc/hosts的第1行:
可以发现所有的行都被显示出来了(第1行重复2次)。—— 正确的用法应该添加 -n 选项,这样就可以只显示第1行了:
行号可以是连续的行号,如打印passwd第3到第6行账户的信息:
2)sed命令的 -r 选项
需要用到扩展正则时,需要加 -r选项
3)sed命令的 -i 选项
正常情况下,sed命令所做的处理只是把操作结果(包括打印、删除等)输出到当前终端屏幕,而并不会对原始文件做任何更改:
若希望直接修改文件内容,应添加选项 -i 。
需要特别注意的是,和一些指令组合和使用的先后顺序都会对最终输出结果产生影响
例如: 指令 -n、和操作操作p
比如,直接删除test.txt(自行创建一个任意内容的文件)的第1~4行:
下文中关于使用sed修改文件的示例中,为了避免大家在练习过程中因误操作导致系统故障,命令省略 –i 选项,不再逐一说明。需要时,大家可自行加上此选项。
4)多个指令可以使用分号隔离
用分号来隔离多个操作,比如:
1)行号案例
2)正则案例
3)没有条件,则表示匹配所有行
四、认识sed工具的 p、d、s 条件指令
1)下面看看sed工具的p指令案例集锦(自己提前生成一个a.txt文件)
2)下面看看sed工具的d指令案例集锦(自己提前生成一个a.txt文件)
3)sed命令的s替换基本功能(s/旧内容/新内容/选项):
4)下面看看sed工具的s指令案例集锦(自己提前生成一个a.txt文件)
注意:替换操作的分隔“/”可改用其他字符,如#、&等,便于修改文件路径
以下操作使用nssw.txt作为测试文件。
参考数据文件内容如下:
5)删除文件中每行的第二个、最后一个字符
分两次替换操作,之一次替换掉第2个字符,第二次替换掉最后一个字符:
6)将文件中每行的之一个、倒数第1个字符互换
每行文本拆分为“第1个字符”、“中间的橘配所有字符”、“倒数第1个字符”三个部分,然后通过替换操作重排顺序为“3-2-1”:
7)删除文件中所有的数字
因原文件内没有数字,行首也没有空格,这里在内容中新增一些数字另外新几行内容 首行添加几行空格,生成一个新测试文件以 nssw2.txt
以nssw2.txt文件为例,删除所有数字、行首空格的操作如下:
8)为文件中每个大写字母添加括号
使用“()”可实现保留功能,所以可参考下列操作解决:
五、认识sed工具的 i、a、c 条件指令
# sed ‘条件指令’ 文件..
sed工具的多行文本处理操作:
基本语法格式案例:
1)sed命令的 i 指定行之前插入基本功能
2)sed命令的a追加基本功能
3)sed命令的c替换基本功能
六、认识sed高级应用 r、w 条件指令
1)sed命令的 r 读取文件
2)sed命令的 w 保存到文件
七、综合案例
1) 综合案例1
linux字符串匹配某一行的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux字符串匹配某一行,Linux命令:字符串匹配某一行,求助Linux下带特殊字符的字符串查找方法!,Linux sed 命令详解的信息别忘了在本站进行查找喔。
成都创新互联科技有限公司,是一家专注于互联网、IDC服务、应用软件开发、网站建设推广的公司,为客户提供互联网基础服务!
创新互联(www.cdcxhl.com)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。创新互联成都老牌IDC服务商,专注四川成都IDC机房服务器托管/机柜租用。为您精选优质idc数据中心机房租用、服务器托管、机柜租赁、大带宽租用,可选线路电信、移动、联通等。
分享标题:Linux命令:字符串匹配某一行(linux字符串匹配某一行)
当前地址:http://www.mswzjz.cn/qtweb/news38/354988.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能