返回顶部
首页 > 资讯 > 操作系统 >Linux的命令行中文本操作有哪些技巧
  • 510
分享到

Linux的命令行中文本操作有哪些技巧

2023-06-12 22:06:51 510人浏览 独家记忆
摘要

本篇内容主要讲解“linux的命令行中文本操作有哪些技巧”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux的命令行中文本操作有哪些技巧”吧!正则表达式翻译领域不乏让人摸不着头脑的词汇,比如

本篇内容主要讲解“linux的命令行中文本操作有哪些技巧”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux的命令行中文本操作有哪些技巧”吧!

正则表达式
翻译领域不乏让人摸不着头脑的词汇,比如“句柄”、“套接字”、“鲁棒性”。当然,“正则表达式”也属于这一类词汇。我刚接触正则表达式的时候,对这个名词感到非常迷惑。深入了解之后,才突然明白,原来所谓的 regular expression, 其实就是“有规律、有模式的字符串”而已。

很少有一门技术,只需要投入少量的学习成本即可获得巨大的价值回报。正则表达式就属于这一类技术。可惜很多人被它密码般的语法形式当头棒喝,甚至连门都不得而入。

为什么你应该学习正则表达式?其一,在实践中应用这门技术其实不难,只需理解为数不多的几个元字符以及并不复杂的语法,就能够获得强大的文本操控能力;其二,正则表达式往往能提供处理文本的最简单最高效的解决方法(有时也许是唯一的解法)。遇上复杂的情况,如果你不会正则表达式,就只好束手无策、黯然神伤了。

正则表达式入门容易,精通却难。本文并不打算挑战此项任务^^

文本检索
grep 命令可以完成简单的文本搜索任务。

先来准备一份文本材料,把 grep 的帮助页保存为文本文件:

代码如下:


> man grep | col -b > grephelp.txt


下面,我想检索 grephelp.txt 文件中所有包含 "find" 这个单词的文本行:

代码如下:


> grep "find" grephelp.txt
    To find all occurrences of the Word `patricia' in a file:
    To find all occurrences of the pattern `.Pp' at the beginning of a line:
    To find all lines in a file which do not contain the words `foo' or


我希望匹配到的文本使用不同的颜色显示,可以添加 --color 选项,默认的颜色是红色。

代码如下:


> grep --color "find" grephelp.txt


我希望在匹配结果中显示文件名和行号,使用 -H 选项可以显示文件名,使用 -n 选项可以显示行号:

代码如下:


> grep -H -n --color "find" grephelp.txt
grephelp.txt:252:     To find all occurrences of the word `patricia' in a file:
grephelp.txt:256:     To find all occurrences of the pattern `.Pp' at the beginning of a line:
grephelp.txt:265:     To find all lines in a file which do not contain the words `foo' or


很多时候,我们需要知道匹配行前后的上下文。-A 和 -B 这两个选项会是你的好朋友。-A n 表示显示匹配行以及其后的 n 行;-B n 表示显示匹配行以及之前的 n 行。现在,我们在匹配行的前后分别额外显示两行:

代码如下:


> grep -A 2 -B 2 -H -n --color "find" grephelp.txt
grephelp.txt-250-
grephelp.txt-251-EXAMPLES
grephelp.txt:252:     To find all occurrences of the word `patricia' in a file:
grephelp.txt-253-
grephelp.txt-254-       $ grep 'patricia' myfile
--
--
grephelp.txt-254-       $ grep 'patricia' myfile
grephelp.txt-255-
grephelp.txt:256:     To find all occurrences of the pattern `.Pp' at the beginning of a line:
grephelp.txt-257-
grephelp.txt-258-       $ grep '^\.Pp' myfile
--
--
grephelp.txt-263-     match any character.
grephelp.txt-264-
grephelp.txt:265:     To find all lines in a file which do not contain the words `foo' or
grephelp.txt-266-     `bar':
grephelp.txt-267-


如果需要查找所有不包含 "find" 的文本行,该怎么做呢?很简单,使用 -v 选项即可。

grep 还有两个变体,egrep 和 fgrep。相对于仅支持基本正则模式(BREs)的 grep 来说,egrep 支持扩展正则模式(EREs),因而检索能力更为强大;fgrep 是所有三个工具中速度最快的一个,因为它完全不支持正则模式。


文本替换
tr 命令可以完成简单的字符转换任务。例如,可以通过 tr 把 grephelp.txt 文件转换为全文大写:

代码如下:


> cat grephelp.txt | tr '[:lower:]' '[:upper:]'


简而言之,tr 的工作就是把第一个集合中的字符转换为第二个集合中的相应的字符。常用的字符集合有下面这些:

[:alnum:]:字母数字
[:alpha:]:字母
[:cntrl:] :控制字符
[:digit:]:数字
[:graph:]: 图形字符
[:lower:]:小写字母
[:print:]:可打印字符
[:punct:]:标点符号
[:space:]:空白字符
[:upper:]:大写字母
[:xdigit:]:十六进制数字
tr 命令的应用场景非常受限,如果希望进行更加灵活的模式替换,我们还有 sed(也就是 stream editor,流编辑器)。

把文件中所有的 "find" 文本替换为 "search":

代码如下:


> sed "s/find/search/g" grephelp.txt


这条命令中,s 表示执行“替换操作”,/find/search/ 表示把 "find" 替换为 "search",g 表示对一行中所有的匹配进行替换。sed 默认把处理结果打印到标准输出,我们可以通过重定向把处理结果转储到一个新文件中,或者使用选项 -i 把结果直接写回原文件(有风险,需谨慎):

代码如下:


> sed -i "s/find/search/g" grephelp.txt


把文件中所有的数字 n 替换为 "--n--" 的形式:

代码如下:


> sed -E "s/([0-9]+)/--\1--/g" grephelp.txt


选项 -E 表示在处理过程中使用扩展的正则模式(EREs),替换命令中的 \1 表示引用正则表达式的第一个捕获分组。请注意,-E 这个选项只在 Mac OS X 系统和 FreeBSD 系统上有效,其他 Unix 系统需要使用另一个等效的选项 -r。

sed 的功能远不止这一些,篇幅所限,不可能详细讲解 sed 的用法。如果希望学习更多,请移步这篇文章。

文本去重

代码如下:


> cat -n sonnet116.txt
    1    Let me not to the marriage of true minds
    2    Admit impediments. Love is not love
    3    Which alters when it alteration finds,
    4    Or bends with the remover to remove:
    5    O, no! it is an ever-fix`ed mark,
    6    O, no! it is an ever-fix`ed mark,
    7    That looks on tempests and is never shaken;
    8    It is the star to every wand'ring bark,
    9    Whose worth's unknown, although his heighth be taken.
   10    Love's not Time's fool, though rosy lips and cheeks
   11    Love's not Time's fool, though rosy lips and cheeks
   12    Love's not Time's fool, though rosy lips and cheeks
   13    Within his bending sickle's compass come;
   14    Love alters not with his brief hours and weeks,
   15    But bears it out even to the edge of doom:
   16    If this be error and upon me proved,
   17    I never writ, nor no man ever loved.


这是莎士比亚的一首十四行诗,只可惜第5行和第10行有重复(而且第10行重复了3次)。怎么查看文本中重复的行呢?uniq 命令可以帮助你。

代码如下:


> uniq -d sonnet116.txt
O, no! it is an ever-fix`ed mark,
Love's not Time's fool, though rosy lips and cheeks


选项 -d 表示仅输出重复的行。如果需要去重,使用不带选项的 uniq 命令就可以了:

代码如下:


> uniq sonnet116.txt
Let me not to the marriage of true minds
Admit impediments. Love is not love
Which alters when it alteration finds,
Or bends with the remover to remove:
O, no! it is an ever-fix`ed mark,
That looks on tempests and is never shaken;
It is the star to every wand'ring bark,
Whose worth's unknown, although his heighth be taken.
Love's not Time's fool, though rosy lips and cheeks
Within his bending sickle's compass come;
Love alters not with his brief hours and weeks,
But bears it out even to the edge of doom:
If this be error and upon me proved,
I never writ, nor no man ever loved.


想要查看每一行究竟重复了多少次?没问题,使用选项 -c:

代码如下:


> uniq -c sonnet116.txt
  1 Let me not to the marriage of true minds
  1 Admit impediments. Love is not love
  1 Which alters when it alteration finds,
  1 Or bends with the remover to remove:
  2 O, no! it is an ever-fix`ed mark,
  1 That looks on tempests and is never shaken;
  1 It is the star to every wand'ring bark,
  1 Whose worth's unknown, although his heighth be taken.
  3 Love's not Time's fool, though rosy lips and cheeks
  1 Within his bending sickle's compass come;
  1 Love alters not with his brief hours and weeks,
  1 But bears it out even to the edge of doom:
  1 If this be error and upon me proved,
  1 I never writ, nor no man ever loved.


文本排序
假设有这样一个报表文件,第一列是月份,第二列是当月的销售个数:

代码如下:


> cat report.txt
March,19
June,50
February,17
May,18
August,16
April,31
May,18
July,26
January,24
August,16


这个文件的内容不仅顺序是乱的,而且还有重复。我希望按字母表顺序排序,可以下面这个命令:

代码如下:


> sort report.txt
April,31
August,16
August,16
February,17
January,24
July,26
June,50
March,19
May,18
May,18


选项 -u (表示 unique)可以在排序结果中去除重复行:

代码如下:


> sort -u report.txt
April,31
August,16
February,17
January,24
July,26
June,50
March,19
May,18


能不能按照月份排序呢?选项 -M (表示 month-sort)可以帮助我们:

代码如下:


> sort -u -M report.txt
January,24
February,17
March,19
April,31
May,18
June,50
July,26
August,16


按照第二列的数字进行排序也是很简单的:

代码如下:


> sort -u -t',' -k2 report.txt
August,16
February,17
May,18
March,19
January,24
July,26
April,31
June,50


上面的例子中,选项 -t',' 表示以逗号为分隔符对文本进行列分割;-k2 表示对第2列进行排序。

当然了,把结果逆序排列也并非不可能:

代码如下:


> sort -u -r -t',' -k2 report.txt
June,50
April,31
July,26
January,24
March,19
May,18
February,17
August,16


文本统计
wc 命令用来完成文本统计工作,通过使用不同的选项,它可以统计文件中的字节数(-c),字符数(-m),单词数(-w)与行数(-l)。

例如,查看 grephelp.txt 这个文件总共有多少个单词:

代码如下:


> wc -w grephelp.txt
   1571 grephelp.txt


查看 sonnet116.txt 这个文件总共有多少不重复的行(废话,十四行诗当然是有14行):

代码如下:


> uniq sonnet116.tx6 | wc -l
     14


你还应该试试 Awk 与 Perl
如果上面介绍的工具仍然不能满足你,也许你需要火力更强的武器。试试 Awk 与 Perl 吧。

Awk 也是一款上古神器,它的年龄可能和 sed 不相上下。Awk 可谓是专门为了文本处理而生,它的语法和特性非常适合用于操纵文本和生成报表。如需学习,请参考 这篇文章,你会喜欢上它的。

长久以来,Perl 背负了“只写语言”的恶名。实际上,只要处理得当,用 Perl 一样可以写出模块清晰的、容易阅读和理解的代码。根据我的经验,使用 Perl 的场合 80% 以上与文本处理有关。Perl 内置的正则表达式支持可能是所有语言中最好的,再加上简洁紧凑的语法以及便利的操作符,这些特性帮助 Perl 成了文本处理领域当仁不让的霸主。

到此,相信大家对“Linux的命令行中文本操作有哪些技巧”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Linux的命令行中文本操作有哪些技巧

本文链接: https://lsjlt.com/news/263230.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Linux的命令行中文本操作有哪些技巧
    本篇内容主要讲解“Linux的命令行中文本操作有哪些技巧”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux的命令行中文本操作有哪些技巧”吧!正则表达式翻译领域不乏让人摸不着头脑的词汇,比如...
    99+
    2023-06-12
  • 实用的Linux命令行技巧有哪些
    小编给大家分享一下实用的Linux命令行技巧有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!输出显示为一个表有时候,当你看到一个命令的输出,由于过度拥挤的字符...
    99+
    2023-06-16
  • Linux文本处理命令的编程技巧有哪些
    Linux文本处理命令的编程技巧有哪些,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。合格的程序员都善于使用工具,正所谓君子性非异也,善假于物也。合理的利用 Linux 的命令行...
    99+
    2023-06-15
  • 有趣的Linux命令行小技巧有哪些
    这篇文章主要为大家展示了“有趣的Linux命令行小技巧有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“有趣的Linux命令行小技巧有哪些”这篇文章吧。1、 在 Linux 中锁定或隐藏文件或...
    99+
    2023-06-16
  • Linux命令行中使用history的技巧有哪些
    这篇文章给大家分享的是有关Linux命令行中使用history的技巧有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1.使用 HISTTIMEFORMAT 显示时间戳当在命令行输入history时,它将显示序...
    99+
    2023-06-15
  • Unix/Linux命令技巧有哪些
    这篇文章给大家分享的是有关Unix/Linux命令技巧有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 删除一个大文件我在生产服务器上有一个很大的200GB的日志文件需要删除。我的rm和ls命令已经崩溃,...
    99+
    2023-06-15
  • 有哪些Unix/Linux命令技巧
    这篇文章主要讲解了“有哪些Unix/Linux命令技巧”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“有哪些Unix/Linux命令技巧”吧!> /path/to/file.l...
    99+
    2023-06-09
  • Linux中命令补齐技巧有哪些
    这篇文章主要为大家展示了“Linux中命令补齐技巧有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux中命令补齐技巧有哪些”这篇文章吧。默认情况下,bash命令行可以自动补全文件或目录...
    99+
    2023-06-13
  • Linux中常用技巧命令有哪些
    小编给大家分享一下Linux中常用技巧命令有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. 终止操作 【ctrl+c】2. 快速的从命令的尾部切换首部【c...
    99+
    2023-06-28
  • linux中命令行操作快捷键有哪些
    这篇文章给大家分享的是有关linux中命令行操作快捷键有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。历史相关命令 !!:执行上一条命令!num:执行历史命令中第num条命令!-num:执行历史命令中倒数第n...
    99+
    2023-06-09
  • linux中Sudo命令的使用技巧有哪些
    这篇文章将为大家详细讲解有关linux中Sudo命令的使用技巧有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。简单的说,sudo 是一种权限管理机制,管理员可以授权于一些普通用户去执行一些 root ...
    99+
    2023-06-28
  • linux中Sudo命令使用技巧有哪些
    这篇文章主要介绍了linux中Sudo命令使用技巧有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。sudo 表示 “superuser do”,它允许已验证的用户以其他用...
    99+
    2023-06-15
  • Linux中VI命令使用技巧有哪些
    这篇文章主要为大家展示了“Linux中VI命令使用技巧有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux中VI命令使用技巧有哪些”这篇文章吧。进入vi命令vi filename :打...
    99+
    2023-06-16
  • win10的基本操作技巧有哪些
    这篇文章主要介绍了win10的基本操作技巧有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇win10的基本操作技巧有哪些文章都会有所收获,下面我们一起来看看吧。win10基本操作技巧:一、如何调整开始菜单中...
    99+
    2023-07-01
  • Linux中有哪些文件与网络操作命令
    今天就跟大家聊聊有关Linux中有哪些文件与网络操作命令,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。ls代码如下:$ ls #查看当前目录下文件conf    ...
    99+
    2023-06-12
  • nmap实用命令行技巧有哪些
    这篇文章将为大家详细讲解有关nmap实用命令行技巧有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1) 获取远程主机的系统类型及开放端口nmap -sS -P0 -sV -O <target&g...
    99+
    2023-06-16
  • Linux文件处理常用命令操作技巧
    我是Linux初学者,做个笔记,以下是Linux几个常用文件处理命令: 命令提示符 [root@localhost~]# 其中:   root 表示当前登录...
    99+
    2022-06-04
    操作技巧 文件 常用命令
  • Linux系统操作mysql基本命令有哪些
    这篇文章跟大家分析一下“Linux系统操作mysql基本命令有哪些”。内容详细易懂,对“Linux系统操作mysql基本命令有哪些”感兴趣的朋友可以跟着小编的思路慢慢深入来阅读一下,希望阅读后能够对大家有所帮助。下面跟着小编一起深入学习“L...
    99+
    2023-06-28
  • linux中历史命令使用技巧有哪些
    这篇文章主要介绍linux中历史命令使用技巧有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!历史命令使用技巧分享几个历史命令的使用技巧,能够提高你的工作效率。!!:重复执行上条命令;!N:重复执行 history...
    99+
    2023-06-27
  • Linux中Git集中操作命令有哪些
    这篇文章主要为大家展示了“Linux中Git集中操作命令有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Linux中Git集中操作命令有哪些”这篇文章吧。SyntaxHighlighterg...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作