【Linux】管道命令

        命令执行的时候有时会输出数据,有的命令输出的数据太繁杂了。

那么我们怎么去筛选这些信息来得到我们所想要的格式?

        这就牵涉到管道命令的问题了(pipe),管道命令使用的是【|】这个界定符号。另外,管道命令与【连续执行命令】是不一样的,这点下面我们再说明。

下面我们先举一个例子来说明一下简单的管道命令

        假设我们想要知道/etc/下面有多少文件,那么可以利用Is/etc来查看,不过,因为/etc下面的文件太多,导致一口气就将屏幕塞满了,不知道前面输出的内容是啥?

        此时,我们可以通过less命令的协助:如此一来,使用Is命令输出后的内容,就能够被 less 读取,并且利用less的功能,我们就能够前后翻动相关的信息了。很方便是吧?

        我们就来了解一下这个管道命令【|】的用途吧!其实这个管道命令【|】仅能处理经由前面一个命令传来的正确信息,也就是标准输出的信息,对于标准错误并没有直接处理的能力。

那么整体的管道命令可以使用下图表示;

        在每个管道后面接的第一个数据必定是【命令】,而且这个命令必须要能够接受标准输入的数据才行,这样的命令才可为管道命令

  • 例如less、more、head、tail 等都是可以接受标准输入的管道命令,
  • 至于例如 Is、cp、mv 等就不是管道命令。因为Is、cp、mv 并不会接受来自stdin 的数据,

也就是说,管道命令主要有两个比较需要注意的地方:

  1. 管道命令仅会处理标准输出,对于标准错误会予以忽略;
  2. 管道命令必须要能够接受来自前一个命令的数据成为标准输入继续处理才行。

想一想,如果你硬要让标准错误可以被管道命令所使用,那该如何处理?

其实就是通过数据流重定向,让2>&1加入命令中,就可以让2>变成1>,了解了吗?

多说无益,让我们来玩一些管道命令吧!下面的东西对系统管理非常有帮助。

1.选取命令:cut、grep

什么是选取命令?

说穿了,就是将一段数据经过分析后,取出我们所想要的,或是经由分析关键词,取得我们所想要的那一行。

不过,要注意的是,一般来说,选取信息通常是针对【一行一行】来分析的,并不是整篇信息分析

下面我们介绍两个很常用的信息选取命令:

1.1.cut

cut 不就是【切】吗?

没错,这个命令可以将一段信息的某一段给它【切】出来,处理的信息是以【行】为单位,下面我们就来谈一谈:

  1. cut  -d   '分隔字符'   -f     fields<==用于有特定分隔字符。
  2. cut   -c    字符区间                   <==用于排列整齐的信息。

选项与参数:

  • -d:后面接分隔字符,与-f一起使用;
  • -f:根据-d的分隔字符将一段信息划分成为数段,用-f 取出第几段的意思;
  • -c:以字符(characters)的单位取出固定字符区间;

        范例一:将PATH变量取出,我要找出第五个路径。


我们是以【:】作为分隔,那么如果想要列出第3段与第5段?,就是这样:

        范例二:将export 输出的信息,取得第12字符以后的所有字符

.…(其他省略)……

#注意看,每个数据都是排列整齐的输出,如果我们不想要【declare-x】时,就得这么做。

……(其他省略)…

#知道怎么回事了吧?用-c可以处理比较具有格式的输出数据,我们还可以指定某个范围的值,例如第12-20的字符、就是cut  -c 12-20等.

.

        范例三:用last 将显示的登录者的信息中,仅留下使用者大名。

last可以输出【账号/终端/来源/日期时间】的数据,并且是排列整齐的。


由输出的结果我们可以发现第一个空白分隔的栏位代表账号,所以使用如上命令.

        但是因为root     pts/1之间空格有好几个,并不是只有一个,pts/1其实不能以cut -d ' ' -f 1,2所以,如果要找出,输出的结果会不是我们想要的。


  

      cut 主要的用途在于将同一行里面的数据进行分解,最常使用在分析一些数据或文字数据的时候。这是因为有时候我们会以某些字符当作划分的参数,然后来将数据加以分割,以取得我们所需要的数据。

不过,cut在处理多空格相连的数据时,可能会比较吃力一点,所以某些时刻可能会使用awk来替换。

1.2.grep

        刚刚的cut是将一行信息当中,取出某部分我们想要的,而grep则是分析一行信息,若当中有我们所需要的信息,就将该行拿出来,

简单的语法是这样的:

  • grep [-acinv] [--color=auto] '查找字符' filename

选项与参数:

  • -a:将二进制文件以文本文件的方式查找数据
  • -c:计算找到‘查找字符’的次数。
  • -i:忽略大小写的不同,所以大小写视为相同
  • -n:顺便输出行号
  • -v:反向选择,亦即显示出没有‘查找字符’内容的那一行。
  • --color=auto:可以将找到的关键字部分加上颜色的显示

范例一:将last当中,有出现root的那一行就显示出来。

        范例二:与范例一相反,只要没有root的就取出


 

        范例三:在last 的输出信息中,只要有root 就取出,并且仅取第一栏。

#在取出root 之后,利用上个命令cut 的处理,就能够仅取得第一栏。

        范例四:取出/etc/man db.conf内含MANPATH的那几行。

#神奇的是,如果加上--color=auto的选项,找到的关键字部分会用特殊颜色显示。

        grep是个很棒的命令,它支持的语法实在是太多了,用在正则表达式里面,能够处理的数据实在是多得很。不过,我们这里先不谈正则表达式,您先了解一下,grep可以解析一行文字,取得关键词,若该行有存在关键词,就会整行列出来。

另外,CentOS7当中,默认的grep已经主动使用--color=auto选项在alias中了。

2.排序命令:sort、wc、uniq

很多时候,我们都会去计算一次数据里面的相同形式的数据总数,举例来说,使用last可以查得系统上面有登录主机者的身份。

那么我可以针对每个用户查出它们的总登录次数吗?

此时就要排序与计算之类的命令来辅助,下面我们介绍几个好用的排序与统计命令。

2.1.sort

        sort 是很有趣的命令,它可以帮我们进行排序,而且可以根据不同的数据形式来排序,例如数字与文字的排序就不一样。

       此外,排序的字符与语系的编码有关,因此,如果您需要排序时,建议使用LANG=C来让语系统一,数据排序比较好一些。

  • sort [-fbMnrtuk] [file or stdin]

选项与参数:

  1. -f:忽略大小写的差异,例如A与a 视为编码相同;
  2. -b:忽略最前面的空格字符部分;
  3. -M:以月份的名字来排序,例如JAN、DEC等的排序方法;
  4. -n:使用【纯数字】进行排序(默认是以文字形式来排序的)反向排序;
  5. -u:就是unig,相同的数据中,仅出现一行代表;
  6. -t:分隔符号,默认是用[Tab]键来分隔;
  7. -k:以哪个区间(field)来进行排序的意思

        范例一:个人账号都记录在/etc/passwd 下,请将账号进行排序


#省略很多的输出,由上面的信息看起来,sort是默认【以第一个】条信息来排序,而且默认是以【文字】形式来排序的,所以由a开始排到最后。

        范例二:/etc/passwd内容是以:来分隔的,我想以第三栏来排序,该如何?

+看到特殊字体的输出部分了吧?怎么会这样排列?呵呵,没错。如果是以文字形式来排序的话,原本就会是这样,想要使用数字排序:


这样才行,用那个-n来告知sort 以数字来排序。

        范例三:利用last,将输出的数据仅显示账号,并加以排序。


 

        sort 同样是很常用的命令,因为我们常常需要比较一些信息。

        举个上面的第二个例子来说,今天假设你有很多的账号,而且你想要知道最大的用户ID目前到哪一个了。呵呵,使用sort 一下子就可以知道答案。当然其使用还不止此,有空的话不妨玩一玩。

2.2.uniq

如果我排序完成了,想要将重复的数据仅列出一个显示,可以怎么做?

  • uniq [-ic]

选项与参数:

  1. -i:忽略大小写字符的不同;
  2. -c:进行计数;

范例一,使用last 将账号列出,仅取出账号栏,进行排序后仅取出一位.


范例二:承上题,如果我还想要知道每个人的登录总次数?

从上面的结果可以发现reboot有6次,root 登录则有23次,大部分是以zs_108来操作.

#wtmp与第一行的空白都是1ast的默认字符,那两个可以忽略的。

这个命令用来将重复的行删除掉只显示一个,

举个例子来说,你要知道这个月份登录你主机的用户有谁,而不在乎它的登录次数,那么就使用上面的范例,(1)先将所有的数据列出;(2)再将人名独立出来;(3)经过排序;(4)只显示一个。由于这个命令是在将重复的东西减少,所以当然需要配合排序过的文件来处理

2.3.wc

如果我想要知道/etc/man_db.conf这个文件里面有多少字?多少行?多少字符的话,可以怎么做?

其实可以利用wc 这个命令来完成,它可以帮我们计算输出信息的整体数据。

  •  wc  [-lwm]

选项与参数:

  1. -l:仅列出行
  2. -w:仅列出多少字(英文字母);
  3. -m:多少字符;

范例一:那个/etc/man db.conf里面到底有多少相关字、行、字符数?

输出的三个数字中,分别代表:【行、字数、字符数】

范例二:使用last可以输出登录者,但是last 最后两行并非账号内容,那么请问。
我该如何以一行命令串取得登录系统的总人次?



由于last 会输出空白行、wtmp、unknown、reboot 等无关账号登录的信息,因此,我利用
grep 取出非空白行,以及去除上述关键字那几行,再计算行数,就能够了解。

wc也可以当作命令?这可不是上洗手间的WC,这是相当有用的计算文件内容的一个工具。

举个例子来说,当你要知道目前你的账号文件中有多少个账号时,就使用这个方法:【cat /etc/passwd|wc -l】因为/etc/passwd里面一行代表一个用户,所以知道行数就晓得有多少的账号在里面了,而如果要计算一个文件里面有多少个字符时,就使用wc-m这个选项。

3.双向重定向:tee

想个简单的东西,我们由知道>会将数据流整个传送给文件或设备,因此我们除非去读取该文件或设备,否则就无法继续利用这个数据流。

万一我想要将这个数据流的处理过程中将某段信息存下来,应该怎么做?

利用tee就可以,我们可以这样简单的看一下:
tee 会同时将数据流分送到文件与屏幕(screen ),而输出到屏幕的,其实就是stdout,那就可以让下个命令继续处理。

  •  tee [-a] file

选项与参数:

  • -a:以累加(append)的方式,将数据加入 file 当中

范例一,让我们将last的输出存一份到last.list 文件中;

范例二则是将 ls的数据存一份到~/homefile,同时屏幕也有输出信息

 

要注意,tee后接的文件会被覆盖,若加上-a 这个选项则能将信息累加。

        tee可以让 standard output转存一份到文件内并将同样的数据继续送到屏幕去处理,这样除了可以让我们同时分析一份数据并记录下来之外,还可以作为处理一份数据的中间缓存记录之用,tee这家伙在很多选择/填空的认证考试中很容易考。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/870233.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

centos 安装ffmpeg

这个错误表明在你的 CentOS 系统的默认仓库中没有 ffmpeg 包。CentOS 的默认仓库通常不包含 ffmpeg&#xff0c;因为它涉及一些许可证问题。但是&#xff0c;你可以通过添加第三方仓库来安装 ffmpeg。 使用 EPEL 和 RPM Fusion 仓库 # 安装 EPEL 仓库 sudo yum install epel-…

编程师适合看什么书:深入探索编程领域的知识宝库

编程师适合看什么书&#xff1a;深入探索编程领域的知识宝库 在编程领域&#xff0c;不断学习是提升技能的关键。选择合适的书籍&#xff0c;对于编程师来说&#xff0c;不仅能够拓宽视野&#xff0c;还能深入掌握各种技术细节。那么&#xff0c;编程师适合看什么书呢&#xf…

引用常用用法

1. 通过传递引用&#xff0c;修改原始变量的值 struct UpdateItem { std::string id; // Unique identifier for the record std::string userId; // Users ID std::string userName; // Users name std::string userDept; // Users department }; int getmessade() { std::ve…

ES6 async 函数详解 (十)

async 函数是什么&#xff1f;一句话&#xff0c;它就是 Generator 函数的语法糖。 const gen function* () {const f1 yield readFile(/etc/fstab);const f2 yield readFile(/etc/shells);console.log(f1.toString());console.log(f2.toString()); };const asyncReadFile …

项目管理工具评测:2024年国内外最顶级的10款项目管理工具排行

国内外涌现出众多优秀的项目管理工具&#xff0c;它们各自在功能、易用性、集成能力等方面展现出独特优势。以下是国内外顶级的10款项目管理工具&#xff1a; 一、进度猫 推荐理由&#xff1a;进度猫以其直观的任务管理和进度跟踪功能&#xff0c;成为许多团队和项目的首选…

MybatisPlus 使用教程

MyBatisPlus使用教程 文章目录 MyBatisPlus使用教程1、使用方式1.1 引入依赖1.2 构建mapper接口 2、常用注解2.1 TableName2.2 TableId2.3 TableField MyBatisPlus顾名思义便是对MyBatis的加强版&#xff0c;但两者本身并不冲突(只做增强不做改变)&#xff1a; 引入它并不会对原…

老年实训室的技能大赛介绍

在当今老龄化社会的背景下&#xff0c;老年护理和服务的质量愈发受到关注。为了提升相关人员的专业技能和服务水平&#xff0c;老年实训室的技能大赛应运而生。 老年实训室的技能大赛通常涵盖了多个方面的考核内容&#xff0c;旨在全面检验参赛者在老年护理与服务领域的综合能力…

ES6 Iterator 与 for...of 循环(五)

Iterator 特性&#xff1a; 统一的接口&#xff1a;无论是数组、字符串还是自定义对象&#xff0c;只要它们有默认的迭代器&#xff0c;就可以使用 for…of 循环进行遍历。可迭代对象&#xff1a;具有 [Symbol.iterator] 属性的对象被认为是可迭代的。[Symbol.iterator] 是一个…

FastAPI 学习之路(三十九)对开发接口进行测试

概况 对于开发好的接口需要进行测试之后才能发布。当我们在开发的时候&#xff0c;没有提前测试&#xff0c;我们也要对我们自己的接口进行测试&#xff0c;那么FastApi自身也带有针对开发的接口进行测试的功能。我们看下FastApi官方给我们提供了什么样的支持。 接口还是基于…

笔记本硬盘数据恢复的6种方法!简单易懂

可以从笔记本电脑硬盘恢复已删除的数据吗&#xff1f; “我不小心删除了笔记本电脑硬盘上的重要数据。请问我可以在笔记本电脑硬盘上恢复已删除的数据吗&#xff1f;如果可以&#xff0c;我应该怎么做才能恢复数据呢&#xff1f;” 很多笔记本电脑用户可能会不小心地从电脑中…

线程冲突案例演示

我们以银行取款经典案例来演示线程冲突现象。 银行取款的基本流程可以分为如下几个步骤。 &#xff08;1&#xff09;用户输入账户、密码&#xff0c;系统判断用户的账户、密码是否匹配。 &#xff08;2&#xff09;用户输入取款金额。 &#xff08;3&#xff09;系统判断账…

JavaSE 面向对象程序设计进阶 IO 练习读取多个对象

练习读取多个对象 用序列化流将对象写入文件 import java.io.*; import java.nio.charset.Charset;public class Main {public static void main(String[] args) throws IOException, ClassNotFoundException {//序列化多个对象Person p1new Person("多多", 男,20)…

梧桐数据库:数据库产品中的自然语言语义分析技术

数据库产品中的自然语言语义分析技术是一项重要的自然语言处理技术&#xff0c;它涉及对自然语言文本进行深度理解和分析&#xff0c;从而识别文本中的实体、关系、情感等语义信息&#xff0c;并将这些信息转化为计算机可以理解和处理的形式。 一、自然语言语义分析技术的定义…

蓝牙 - Terminal I/O Service Specification

1, Introduction 1.1, Scope 通过该服务&#xff0c;终端 I/O 客户端设备可连接终端 I/O 服务器设备并与之交互&#xff0c;从而实现串行数据和 GPIO 状态信息的双向交流。 终端 I/O 服务公开本地 UART 数据和本地 GPIO 状态变化&#xff0c;并允许 GATT 客户向 GATT 服务器传…

Elasticsearch 基础查询语句汇总

Elasticsearch 基础查询语句汇总 准备条件指定id查询一指定id查询二指定多个id查询区间查询模糊查询多字段查询分页查询查询总数量 准备条件 以下查询操作都基于索引crm_clue来操作&#xff0c;索引已经建过了&#xff0c;本文主要讲Elasticsearch查询语句&#xff0c;下面开始…

DP学习——设计模式代码采集

学而时习之&#xff0c;温故而知新。 c&#xff0b;&#xff0b;代码 1111https://blog.csdn.net/xushuilong/article/details/106962825 22222

电商之订单价税拆分实现方案

文章目录 案例数据实现思路1、计算出平均金额2、计算每个商品的金额 实现方案1、订单 order 实体2、订单明细 orderDetail 实体3、实现类4、测试启动5、实现结果 在做电商项目的时候&#xff0c;会遇到要对订单明细进行纳税金额拆分&#xff0c;即将税额拆分到每个商品上&#…

Android 自定义Edittext 和TextView 提示文字和填入内容不同的粗细组件

近期项目中又EditText 以及TextView 这两个组件需要用到提示文字 以及 填入文字要保持不同的粗细程度,所以记录一下 首先 是EditText 组件的自定义 BLEditText 继承的这个组件是一个三方的组件,可以在很大程度上减少drawable的编写,有兴趣的可以去相关的Git去看一下 点击查看,…

[leetcode]maximum-binary-tree 最大二叉树

. - 力扣&#xff08;LeetCode&#xff09; class Solution { public:TreeNode* constructMaximumBinaryTree(vector<int>& nums) {return construct(nums, 0, nums.size() - 1);}TreeNode* construct(const vector<int>& nums, int left, int right) {if …

人工智能算法工程师(中级)课程4-sklearn机器学习之回归问题与代码详解

大家好&#xff0c;我是微学AI&#xff0c;今天给大家介绍一下人工智能算法工程师(中级)课程4-sklearn机器学习之回归问题与代码详解。回归分析是统计学和机器学习中的一种重要方法&#xff0c;用于研究因变量和自变量之间的关系。在机器学习中&#xff0c;回归算法被广泛应用于…