谈谈Linux下的数据流重定向和管道命令

简介: 一、标准输入、标准输出、错误输出概述   1.标准输入(stdin)是指令数据的输入,代码为0,使用,默认在屏幕显示。   3.标准错误输出(stderr)是指令执行失败返回的错误信息,代码为2,使用2>或者2>>,默认是屏幕。

一、标准输入、标准输出、错误输出概述

  1.标准输入(stdin)是指令数据的输入,代码为0,使用<或者<<,默认是键盘。

  2.标准输出(stdout)是指令执行成功返回的结果,代码为1,使用>或者>>,默认在屏幕显示。

  3.标准错误输出(stderr)是指令执行失败返回的错误信息,代码为2,使用2>或者2>>,默认是屏幕。

二、数据流重定向的使用
      1."<":指定输入的数据媒介来源(tr 'a-z' 'A-Z' < 文件名:将指定文件中的小写字母变为大写字母输出到屏幕)

   2.">"、"1>":将正确的内容覆盖输出到指定的媒介

   3.">>"、"1>>":将正确的内容追加到指定的媒介

   4."2>":将错误覆盖输出到指定的媒介

   5."2>>":将错误信息追加输出到指定的媒介

   6."&>":将正确内容和错误信息覆盖输出到指定媒介

   7."&>>":将正确内容和错误信息追加到指定的媒介

   8.多个指令执行
            bash1&&bash2(前者执行成功才会执行后者)

     bash1||bash2(前者执行完毕且失败才执行后者)

三、管道命令概述

  1.管道命令能够将一个命令的执行结果经过筛选,只保留我们需要的信息。 如,/etc目录下会有大量的文件,如果使用ls很难找到需要的文件,因此可以使用管道命令将ls的结果进行一次筛选,只保留需要的信息。 

  2.管道和数据流重定向的区别:

    管道一词非常生动形象,原始数据经过管道后,管道会将一部分不需要的信息过滤掉,只保留用户所关注的信息。

    数据流重定向是指定数据在哪里显示,默认情况下会在屏幕显示,我们可以指定它输出到文件。

  3.管道命令通过管道符"|"连接

  4.能够接收标准输入(stdin),如tail/more/grep等

  5.能够接收来自前一个指令的数据成功stdin进行处理

四、管道命令的使用

  1.cut:为剪切的意思,它能将一行行的数据按照指定的分隔符切成一列列,然后只显示特定列的数据.

    cut -d '分隔符' -f n 按照特定的分隔符将数据切分,并只显示第n列的数据。

    cut -c 起始字符的下标-结束字符的下标 选择特定范围内的数据(cut中涉及的下标均从1开始)

  2.grep:关键字查找

    grep [-cinv] [--color=auto] '关键词' 待查找的文件名

      -c:统计关键词出现的次数

      -i:关键词忽略大小写

      -n:输出行号

      -v:反向选择,即查找不包含该关键字的行

      --color=auto:关键词高亮

    命令 | grep [-参数] ‘关键词’  采用管道,将前一个命令的执行结果输出给grep,并通过grep的关键词搜索将符合条件的行搜索出来。

  3.sort:排序

    sort [-参数] 文件

      -t:指定分隔符

      -k:选取分隔符后的第几个字段进行排序

      -f:排序时忽略选取字段的大小写

      -b:取出选取字段前的空格

      -M:将选取的字段按照月份来排序(前提是选取字段就是月份)

      -n:将选取字段按照数据来排序(前提是选取字段就是数字)

      -r:反向排序

      -u:去重,若选取字段有重复,则去掉重复

    命令 | sort [-参数]   使用管道,将前一个命令执行的结果按照指定字段进行排序。

  4.uniq:只能用于管道,它能够去除前一个命令执行的结果中完全一样的行。

    uniq [-参数] -i:忽略大小写 -c:进行重复行的统计

  5.wc:统计字数、行数、字符数

    wc [-参数] 文件名

     -l 列出行数

     -w 列出字数

     -c 列出字符数

  6.tee:能够同时将命令执行的结果输出到指定的文件和屏幕。只能结合管道使用

    tee [-a] 文件 -a:以追加的形式写入文件。

  7.join:连接两个文件

    这个命令与管道无关。 它相当于数据库中的join连接,将两张表中指定字段,且字段相同的行连接起来。在这里,它能够将两个文件中指定字段的相同字段连接起来,并成一行。

    join [-参数] 文件1 文件2

      -t:两个文件的字段分隔符

      -1:第一个文件的字段

      -2:第二个文件的字段

      -i:忽略所选字段的大小写

  8.split:该命令能将一个大文件切分成若干个小文件。

    split [-参数] 大文件 小文件名字前缀

      -b:指定小文件的大小,需要加上单位:b、k、m -l:指定每个小文件中的行数。  

    大文件会被切分成若干个小文件,且小文件的名字为:小文件名字前缀+aa、小文件名字前缀+ab、小文件名字前缀+ac.

      

相关文章
|
24天前
|
Linux 网络安全 数据安全/隐私保护
Linux 超级强大的十六进制 dump 工具:XXD 命令,我教你应该如何使用!
在 Linux 系统中,xxd 命令是一个强大的十六进制 dump 工具,可以将文件或数据以十六进制和 ASCII 字符形式显示,帮助用户深入了解和分析数据。本文详细介绍了 xxd 命令的基本用法、高级功能及实际应用案例,包括查看文件内容、指定输出格式、写入文件、数据比较、数据提取、数据转换和数据加密解密等。通过掌握这些技巧,用户可以更高效地处理各种数据问题。
57 8
|
24天前
|
监控 Linux
如何检查 Linux 内存使用量是否耗尽?这 5 个命令堪称绝了!
本文介绍了在Linux系统中检查内存使用情况的5个常用命令:`free`、`top`、`vmstat`、`pidstat` 和 `/proc/meminfo` 文件,帮助用户准确监控内存状态,确保系统稳定运行。
153 6
|
25天前
|
Linux
在 Linux 系统中,“cd”命令用于切换当前工作目录
在 Linux 系统中,“cd”命令用于切换当前工作目录。本文详细介绍了“cd”命令的基本用法和常见技巧,包括使用“.”、“..”、“~”、绝对路径和相对路径,以及快速切换到上一次工作目录等。此外,还探讨了高级技巧,如使用通配符、结合其他命令、在脚本中使用,以及实际应用案例,帮助读者提高工作效率。
67 3
|
7天前
|
Linux Shell
Linux 10 个“who”命令示例
Linux 10 个“who”命令示例
33 14
Linux 10 个“who”命令示例
|
16天前
|
Linux 数据库
Linux中第一次使用locate命令报错?????
在Linux CentOS7系统中,使用`locate`命令时出现“command not found”错误,原因是缺少`mlocate`包。解决方法是通过`yum install mlocate -y`或`apt-get install mlocate`安装该包,并执行`updatedb`更新数据库以解决后续的“can not stat”错误。
30 9
|
14天前
|
监控 网络协议 Linux
Linux netstat 命令详解
Linux netstat 命令详解
|
20天前
|
运维 监控 网络协议
运维工程师日常工作中最常用的20个Linux命令,涵盖文件操作、目录管理、权限设置、系统监控等方面
本文介绍了运维工程师日常工作中最常用的20个Linux命令,涵盖文件操作、目录管理、权限设置、系统监控等方面,旨在帮助读者提高工作效率。从基本的文件查看与编辑,到高级的网络配置与安全管理,这些命令是运维工作中的必备工具。
64 3
|
24天前
|
存储 运维 Linux
如何在 Linux 系统中使用 envsubst 命令替换环境变量?
`envsubst` 是 Linux 系统中用于替换文本中环境变量值的实用工具。本文分三部分介绍其工作原理、使用方法及实际应用,包括配置文件替换、脚本执行中环境变量替换和动态生成文件等场景,帮助用户高效利用 `envsubst` 进行开发和运维工作。
40 4
|
24天前
|
运维 监控 Linux
别再只会使用简单的 ping 命令了,Linux 中这些高级 ping 命令可以提高工作效率!
在 Linux 系统中,ping 命令不仅用于检测网络连通性和延迟,还拥有多种高级选项和技巧,如定制数据包大小、获取详细统计信息、持续 ping、指定源地址和多目标 ping。本文详细介绍这些高级命令及其在性能测试、故障排查和网络监控中的实际应用,帮助你提升网络管理效率。
94 3
|
23天前
|
Linux
在 Linux 系统中,`find` 命令
在 Linux 系统中,`find` 命令
25 1