Linux重定向是指修改原来默认的一些东西,对原来系统命令的默认执行方式进行改变,比如说简单的我不想看到在显示器的输出而是希望输出到某一文件中就可以通过Linux重定向来进行这项工作。 Linux默认输入是键盘,输出是显示器。你可以用重定向来改变这些设置。比如用wc命令的时候本来是要手动输入一篇文字来计算字符数的,用了重定向后可以直接把一个已经写好的文件用‘<’指向这条命令,就直接可以统计这个文件的字符数等了。输出也是一样,你可以把屏幕输出重定向到一个文件里,再到文件里去看结果。重定向操作符可以用来将命令输入和输出数据流从默认位置重定向到其他位置,其输入或输出数据流的位置称为句柄;常见的句柄有三种,当然句柄可以自行扩展,一般的OS都提供类似的功能。句柄 句柄代号 句柄描述 STDIN 0 键盘输入 STDOUT 1 输出信息到提示符窗口 STDERR 2 输出错误信息到提示符窗口 默认的 < 重定向输入操作符是 0,而默认的 > 重定向输出操作符是 1。键入 < 或 > 操作符之后,必须指定数据的读写位置,可以是文件名或其他现有的句柄。 要指定重定向到现有句柄,请使用与 & 字符,后面接要重定向的句柄号(即 &句柄号)。 例如,下面的命令可以将句柄 2(即 STDERR)重定向到句柄 1(即 STDOUT):2>&1 下表列出了可用于重定向输入和输出数据流的操作符:
现在我们回过头来看看上面的那条语句mysh > mylog.txt 2>&1就可明白: > mylog.txt意思是将标准输出重定向到mylog.txt,等价于mysh 1> mylog.txt; 2 >& 1 意思是将错误输出重定向到句柄1标准输出;综合起来就是mysh命令执行过程中产生的标准输出和错误输出都会被重定向到mylog.txt中; 重定向的功能十分强大,有兴趣的可以去尝试各种不同的组合,看看前后位置变下会有什么结果? 某些时候我们可能并不希望记录什么标准输出或者是错误输出,那可以用mysh >null 2>null或者mysh >/dev/null 2>/dev/null; I/O重定向详解 1、 基本概念(这是理解后面的知识的前提,请务必理解)
2、 基本IO
3、 进阶IO
上述所有形式都可以前导一个数字,此时建立的文件描述符由这个数字指定而不是缺省的 0 或 1。如: … 2>file 运行一个命令并把错误输出(文件描述符 2)定向到 file。 … 2>&1 运行一个命令并把它的标准输出和输出合并。(严格的说是通过复制文件描述符 1 来建立文件描述符 2 ,但效果通常是合并了两个流。) 我们对 2>&1详细说明一下 :2>&1 也就是 FD2=FD1 ,这里并不是说FD2 的值 等于FD1的值,因为 > 是改变送出的数据信道,也就是说把 FD2 的 “数据输出通道” 改为 FD1 的 “数据输出通道”。如果仅仅这样,这个改变好像没有什么作用,因为 FD2 的默认输出和 FD1的默认输出本来都是 monitor,一样的!但是,当 FD1 是其他文件,甚至是其他 FD 时,这个就具有特殊的用途了。请大家务必理解这一点。
这样就完成了Linux重定向的学习。 原文出自【比特网】,转载请保留原文链接:http://soft.chinabyte.com/os/451/11757951.shtml 1重定向 1.1 重定向符号 > 输出重定向到一个文件或设备 覆盖原来的文件 > ! 输出重定向到一个文件或设备 强制覆盖原来的文件 >> 输出重定向到一个文件或设备 追加原来的文件 < 输入重定向到一个程序 1.2标准错误重定向符号 2> 将一个标准错误输出重定向到一个文件或设备 覆盖原来的文件 b-shell 2>> 将一个标准错误输出重定向到一个文件或设备 追加到原来的文件 2>&1 将一个标准错误输出重定向到标准输出 注释:1 可能就是代表 标准输出 >& 将一个标准错误输出重定向到一个文件或设备 覆盖原来的文件 c-shell |& 将一个标准错误 管道 输送 到另一个命令作为输入 1.3命令重导向示例 在 bash 命令执行的过程中,主要有三种输出入的状况,分别是:
将显示的结果输出到 list.txt 文件中,若该文件以存在则予以取代!
将显示的结果累加到 list.txt 文件中,该文件为累加的,旧数据保留!
将显示的数据,正确的输出到 list.txt 错误的数据输出到 list.err
将显示的数据,不论正确或错误均输出到 list.txt 当中!错误与正确文件输出到同一个文件中,则必须以上面的方法来写!不能写成其它格式!
将显示的数据,正确的输出到 list.txt 错误的数据则予以丢弃! /dev/null ,可以说成是黑洞装置。为空,即不保存。 1.4为何要使用命令输出重导向 • 当屏幕输出的信息很重要,而且我们需要将他存下来的时候; • 背景执行中的程序,不希望他干扰屏幕正常的输出结果时; • 一些系统的例行命令(例如写在 /etc/crontab 中的文件)的执行结果,希望他可以存下来时; • 一些执行命令,我们已经知道他可能的错误讯息,所以想以『 2> /dev/null 』将他丢掉时; • 错误讯息与正确讯息需要分别输出时。 2 管线命令 ( pipe ) 就如同前面所说的, bash 命令执行的时候有输出的数据会出现,那么如果这群数据必需要经过几道手续之后才能得到我们所想要的格式,应该如何来设定?这就牵涉到管线命令的问题了( pipe ),管线命令使用的是『 | 』。 例子:简单的管线命令 假设我们要读取 last 这个指令中,那个 root 登入的『次数』应该怎么作? 那么我所进行的步骤是:
由于 last 的输出是一行代表一次登入,所以只要计算几行就代表登入几次的意思,经由上面三个步骤,将 last 数据逐步的筛选,就可以得到我们的数据了!整个命令可以写成如下:
这个管线命令『 | 』仅能处理经由前面一个指令传来的正确信息,也就是standard output ( STDOUT ) 的信息,对于 stdandard error 并没有直接处理的能力。 2.1基本的管线命令指令介绍 • cut 语法:[root @test /root ]# cut -d “分隔字符” [-cf] fields 参数说明: -d :后面接的是用来分隔的字符,预设是『空格符』 -c :后面接的是『第几个字符』 -f :后面接的是第几个区块? 范例:[root @test /root]# cat /etc/passwd | cut -d “:” -f 1 将 passwd 这个文件里面,每一行里头的 : 用来作为分隔号,而列出第一个区块!也就是姓名所在啦! [root @test /root]# last | cut -c1-20 将 last 之后的数据,每一行的 1-20 个字符取出来! • sort 语法:[root @test /root ]# sort [-t 分隔符] [(+起始)(-结束)] [-nru] 参数说明: -t 分隔符:使用分隔符来隔开不同区间,预设是 tab +start -end:由第 start 区间排序到 end 区间 -n :使用『纯数字』排序(否则就会以文字型态来排序) -r :反向排序 -u :相同出现的一行,只列出一次! 范例:
• wc 语法:[root @test /root ]# wc [-lmw] 参数说明: -l :多少行 -m :多少字符 -w :多少字 范例:
• uniq这个指令用来将『重复的行删除掉只显示一个』 语法:[root @test /root ]# uniq 范例:
• tee命令重定向到文件的同时将数据显示在屏幕上 语法:[root @test /root ]# last | tee last.list | cut -d ” ” -f1 范例:
• tr 语法:[root @test /root ]# tr [-ds] SET1 参数说明: -d :删除 SET1 这个字符串 -s :取代掉重复的字符! 范例:
• split 语法:[root @test /root ]# split [-bl] 输入文件 输出文件前导字符 参数说明: -b :以文件 size 来分 -l :以行数来分 范例:
说明:在 Linux 底下就简单的多了!你要将文件分割的话,那么就使用 -b size 来将一个分割的文件限制其大小,如果是行数的话,那么就使用 -l line 来分割! 管线命令在 bash 的连续的处理程序中是相当重要的!另外,在 log file 的分析当中也是相当重要的一环。 管道输送到一个命令的标准输入可以使用标准输入参数”-“ 进行更仔细的控制.如cat命令的示例 (责任编辑:IT) |