位置: 编程技术 - 正文

Linux的命令行中一些文本操作技巧的实例分享(linux的命令行指的是什么)

编辑:rootadmin

推荐整理分享Linux的命令行中一些文本操作技巧的实例分享(linux的命令行指的是什么),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:linux中命令详解,linux命令行在哪,总结linux命令行的主要用法,linux中的命令及含义,总结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.txtgrephelp.txt:: To find all occurrences of the word `patricia' in a file:grephelp.txt:: To find all occurrences of the pattern `.Pp' at the beginning of a line:grephelp.txt:: 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.txtgrephelp.txt--grephelp.txt--EXAMPLESgrephelp.txt:: To find all occurrences of the word `patricia' in a file:grephelp.txt--grephelp.txt-- $ grep 'patricia' myfile----grephelp.txt-- $ grep 'patricia' myfilegrephelp.txt--grephelp.txt:: To find all occurrences of the pattern `.Pp' at the beginning of a line:grephelp.txt--grephelp.txt-- $ grep '^.Pp' myfile----grephelp.txt-- match any character.grephelp.txt--grephelp.txt:: To find all lines in a file which do not contain the words `foo' orgrephelp.txt-- `bar':grephelp.txt--如果需要查找所有不包含 "find" 的文本行,该怎么做呢?很简单,使用 -v 选项即可。

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

文本替换tr 命令可以完成简单的字符转换任务。例如,可以通过 tr 把 grephelp.txt 文件转换为全文大写:复制代码代码如下:> cat grephelp.txt | tr '[:lower:]' '[:upper:]'简而言之,tr 的工作就是把第一个集合中的字符转换为第二个集合中的相应的字符。常用的字符集合有下面这些:

Linux的命令行中一些文本操作技巧的实例分享(linux的命令行指的是什么)

[: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 sonnet.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. Love's not Time's fool, though rosy lips and cheeks Love's not Time's fool, though rosy lips and cheeks 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.这是莎士比亚的一首十四行诗,只可惜第5行和第行有重复(而且第行重复了3次)。怎么查看文本中重复的行呢?uniq 命令可以帮助你。复制代码代码如下:> uniq -d sonnet.txtO, no! it is an ever-fix`ed mark,Love's not Time's fool, though rosy lips and cheeks选项 -d 表示仅输出重复的行。如果需要去重,使用不带选项的 uniq 命令就可以了:复制代码代码如下:> uniq sonnet.txtLet me not to the marriage of true mindsAdmit impediments. Love is not loveWhich 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 cheeksWithin 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 sonnet.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.txtMarch,June,February,May,August,April,May,July,January,August,这个文件的内容不仅顺序是乱的,而且还有重复。我希望按字母表顺序排序,可以下面这个命令:复制代码代码如下:> sort report.txtApril,August,August,February,January,July,June,March,May,May,选项 -u (表示 unique)可以在排序结果中去除重复行:复制代码代码如下:> sort -u report.txtApril,August,February,January,July,June,March,May,能不能按照月份排序呢?选项 -M (表示 month-sort)可以帮助我们:复制代码代码如下:> sort -u -M report.txtJanuary,February,March,April,May,June,July,August,按照第二列的数字进行排序也是很简单的:复制代码代码如下:> sort -u -t',' -k2 report.txtAugust,February,May,March,January,July,April,June,上面的例子中,选项 -t',' 表示以逗号为分隔符对文本进行列分割;-k2 表示对第2列进行排序。

当然了,把结果逆序排列也并非不可能:复制代码代码如下:> sort -u -r -t',' -k2 report.txtJune,April,July,January,March,May,February,August,

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

例如,查看 grephelp.txt 这个文件总共有多少个单词:复制代码代码如下:> wc -w grephelp.txt grephelp.txt查看 sonnet.txt 这个文件总共有多少不重复的行(废话,十四行诗当然是有行):复制代码代码如下:> uniq sonnet.tx6 | wc -l 你还应该试试 Awk 与 Perl如果上面介绍的工具仍然不能满足你,也许你需要火力更强的武器。试试 Awk 与 Perl 吧。

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

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

Linux中将网络管理器由NetworkManager切换为systemd-network 在Linux世界里,对systemd的采用一直是激烈争论的主题,它的支持者和反对者之间的战火仍然在燃烧。到了今天,大部分主流Linux发行版都已经采用了system

Linux下用于对比文件的diff命令使用教程 总览diff[选项]源文件目标文件描述在最简单的情况是,diff比较两个文件的内容(源文件和目标文件).文件名可以是-由标准输入设备读入的文本.作为特别

在USB磁盘上制作Linux的GRUB引导的方法 GNUGRUB(GRandUnifiedBootloader简称GRUB)是一个来自GNU项目的多操作系统启动程序。GRUB是多启动规范的实现,它允许用户可以在计算机内同时拥有多个操作系

标签: linux的命令行指的是什么

本文链接地址:https://www.jiuchutong.com/biancheng/353393.html 转载请保留说明!

上一篇:Linux系统中tr命令删除和替换文本字符的基本用法(linux tr命令详解)

下一篇:Linux中将网络管理器由NetworkManager切换为systemd-network(linux网络系统管理)

  • 自行研发的无形资产不确认递延所得税
  • 水利建设专项资金收入优惠政策
  • 个人免征税额
  • 不能抵扣的增值税进项税额是什么
  • 中级报名的报考条件要求
  • 一般纳税人厂房出租怎么开票
  • 银行利息月末结算方式
  • 调整汇算清缴利息怎么算
  • 契税印花税的会计分录怎么写
  • 长期股权投资会减值损失吗
  • 专利费代缴
  • 招待费进项税额转出会计分录
  • 收到的油费预付怎么入账
  • 受托方的计税价格是什么意思
  • 非居民企业的征税范围
  • 价内税与价外税的计算公式
  • 小微企业计算公式
  • 普通发票年份代码有什么具体含义?
  • 小规模纳税人定额发票累计领用金额
  • 建筑行业挂靠什么意思
  • 哪些工资薪酬可以进行税前扣除?
  • 企业代扣员工社保怎样做分录
  • 以前年度的库存商品出现负数今年如何入账
  • 给员工小孩买礼物合适吗
  • 王者荣耀中扁鹊的克星是谁
  • 调解仲裁法什么时候实施
  • PHP:mb_substr_count()的用法_mbstring函数
  • 高薪技术企业研发费用标准
  • 包装物损坏无法确认
  • PHP:ftp_get_option()的用法_FTP函数
  • 安博塞利国家公园狮子
  • 债券转换是什么意思
  • 自愿放弃增值税优惠怎么写
  • 开发费用怎么入账
  • 企业所得税退税流程
  • 程序员 cr
  • 宝塔主机分销系统设计
  • 外经证过期没有注销罚款多少
  • 进项税加计抵减是什么意思
  • python PyQt如何使用资源
  • 个人开具工程款发票
  • 招待客户发生的住宿费可以抵扣吗
  • 现代服务包括哪些内容是什么
  • 废品材料回收的会计分录
  • 增值税申报表填写顺序
  • 运输途中的合理损耗计入入账价值
  • 定期定额纳税申报表计税依据怎么填
  • 利润表和资产负债表不平的原因
  • 外贸年底抵扣不抵税
  • 当月作废的发票是否需要报税
  • 预付账款如何调平
  • 长期股权投资的账务处理
  • 已经认证的进项票销售方冲红了
  • 进项税额减免部分在重点税源表中怎么填
  • 外聘人员个人简历
  • 累计折旧税率
  • 应交税费科目账务处理
  • 什么情况下投资乘数最大
  • windows2008关闭ie增强
  • 在windowsxp中删除文件
  • linux终端基础命令
  • un_a.exe
  • ubuntu20.04忘记root密码
  • 升级 win10
  • linux备份恢复
  • qt for 安卓
  • perl chr
  • javascrapt
  • unity3d物体移动代码
  • js 键盘码
  • AppWidgetProvider使用介绍
  • Centos6.8下Node.js安装教程
  • javascript内置对象window
  • javascript面向对象编程指南
  • jquery easyui datagrid实现增加,修改,删除方法总结
  • 企业购票员有风险吗
  • 个人所得税核定征收的政策
  • 税控盘服务费必须每年交吗为什么
  • 餐饮发票真伪查询系统
  • 用电稽查工作总结
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设