linux命令输出重定向 linux 输入输出重定向

&1'>Linux 重定向符号以及2>&1 一个进程默认会打开标准输入、标准输出、错误输出三个文件描述符
文件描述符为0,小于号表示数据由文件流入命令
usage:
命令file
#加入输入重定向,对输入文件进行计数
wc -l/etc/passwd
文件描述符为1,大于号表述数据由命令流入文件
所以: echo "hello"t.log 也可以写成 echo "hello" 1t.log
会把文件的内容清空,再输入到新的文件
会把当前内容保持不变 , 然后在下一行进行追加
2错误重定向,如果当前命令产生了错误,会把错误重定向到文件中,而不会打印到屏幕
无论内容正确还是错误都会把文件输出到文件中 。
stderr的文件描述符为2,Unix程序会向stderr流中写入错误信息 。
默认情况下,commandfile 将stdout 重定向到 file, commandfile 将stdin 重定向到 file 。
如果希望 stderr 重定向到 file,可以这样写:
$ command 2file
如果希望 stderr 追加到 file 文件末尾,可以这样写:
$ command 2file2 表示标准错误文件(stderr)
如果希望将 stdout 和 stderr 合并后重定向到 file,可以这样写:
$ commandfile 21 或者 $ commandfile 21
如果希望对 stdin 和 stdout 都重定向,可以这样写:
$ commandfile1 file2
command 命令将 stdin 重定向到 file1,将 stdout 重定向到 file2 。
含义:将标准错误输出 重定向到 标准输出 。
符号是一个整体 , 不可分开 , 分开后就不是上述含义了 。
比如有些人可能会这么想:2是标准错误输入 , 1是标准输出,是重定向符号 , 那么"将标准错误输出重定向到标准输出"是不是就应该写成"21"就行了?是这样吗? 如果是尝试过,你就知道21的写法其实是将标准错误输出重定向到名为"1"的文件里去了
Linux标准输入输出与重定向详解|果断收藏 linux中的、、、、2、2、21、、,总归要面对的
为了更好的理解这个问题,我们需要追本溯源 。
执行一个shell命令行时通常会自动打开三个标准文件
(1) 、标准输入文件(stdin)
通常对应终端的键盘 。
(2)、标准输出文件(stdout) 。
(3)、标准错误输出文件(stderr) 。
(2)和(3)这两个文件都对应终端的屏幕 。
进程将从标准输入文件中得到输入数据 。
将正常输出数据输出到标准输出文件[显示器] 。
将错误信息送到标准错误文件中[显示器] 。
下图所示:
0、1、2表示一个文件描述符
但是,有时候我们不想把一些进程处理后信息输出到显示器 。
这时我们就引出了重定向 。
改变标准输入/输出的方向
三种重定向:
1、重定向标准输出,包括两种 。
(1)、(覆盖),等价1
将命令执行的结果输出到指定文件 , 非显示器 。
【linux命令输出重定向 linux 输入输出重定向】 (2) 、(追加) , 等价1
将命令执行的结果追加到指定文件,非显示器 。
2、 重定向标准输入,包括两种 。
(1) 、
将命令中接收的输入途径,由键盘改为指定文件 。
(2) 、[Here Document]
命令序列传递到一个交互程序或者命令中 。
3、 重定向标准错误,包括两种 。
(1) 、2(覆盖)
将命令执行的结果输出到指定文件 。
(2) 、2(追加)
将命令执行的结果追加到指定文件 。
1、重定向标准输出和重定向标准错误到同一个文件中
有以下的几种方式
(1) 、21
(2) 、
(3) 、
2、 两个特殊文件

推荐阅读