重定向:人为干预决定输出结果的位置【输出到文件还是控制台】
比如 :
ls /aaaaa # 不存在aaaaa这个目录,会报错
返回
要将1和2的结果都放到bbb中,需要首先将1重定向到bbb文件,即
ls / /aaaaaa 1>bbb 2>&1
或者
ls / /aaaaaa >&bbb #特殊写法而已,不用深究
或者
ls / /aaaaaa &>bbb #特殊写法而已,不用深究
返回
<<<从一个字符串读数据、<<给定结束符自己输数据、<从文件进行输入
也可以放到文件中执行,shell_eg.sh中的内容如下
cat >>aaa <<rg 或者 cat <<rg >>aaa
cat aaa
返回
注:read是读取的,不是输出,不能把结果重定向到文件
关于linux bash的重定向
所谓I/O重定向简单来说就是一个过程,这个过程捕捉一个文件,或者命令,程序,脚本,甚至脚本中的代码块(code block)的输出,然后把捕捉到的输出,作为输入发送给另外一个文件,命令,程序,或者脚本。
如果谈到I/O重定向,就涉及到文件标识符(File Descriptor)的概念, 在Linux系统中,系统为每一个打开的文件指定一个文件标识符以便系统对文件进行跟踪,这里有些和C语言编程里的文件句柄相似,文件标识符是一个数字,不同数字代表不同的含义,默认情况下,系统占用了3个,分别是0标准输入(stdin),1标准输出(stdout), 2标准错误(stderr), 另外3-9是保留的标识符,可以把这些标识符指定成标准输入,输出或者错误作为临时连接。通常这样可以解决很多复杂的重定向请求。
标准输入通常指键盘的输入
标准输出通常指显示器的输出
标准错误通常也是定向到显示器
请看以下例子,来描述一下他们的关系
#ls /dev
这个命令列出/dev目录下的所有文件,在屏幕上输出结果。
这里 /dev 就是作为命令ls的标准输入(从键盘输入),而打印在屏幕的结果就是标准输出(/dev目录中的内容)
还是回到标题,重定向就是把标准的`输入或者输出更改成其他的方式,请参看如下例子
或者等同于
#ls /dev 1>filename #注意:"1"和">"中间没有空格
以上命令会把命令的标准输出重新定向到一个文件filename,而不是显示到屏幕上,如果不指明文件标识符,系统默认的就是1, 因此1可以省略
如果把上面例子重的">"改成">>"则表示把输出追加到filename文件的末尾,如果文件不存在则创建它。如下
#ls /dev >>filename
也可以把标准错误重新定向到文件
#ls -qw /dev 2>filename
显然 -qw是一个错误参数,通常会在显示器上报告一个错误信息,但由于把2标准错误(stderr)重新定向到了文件filename,因此显示器没有错误信息,而信息写到了文件里面
以下命令是把标准输出和错误都定向到文件
#ls /dev &>filename
"&"在这里代表标准输出和标准错误,这里无论是正常输出还是错误信息都写到filename中了。
重新定义标准输入,输出,和错误的文件标识符
重新定义文件标识符可以用i>&j命令,表示把文件标识符i重新定向到j,你可以把"&"理解为"取地址"
请看以下例子
#exec 5>&1
表示把文件标识符5定向到标准输出,这个命令通常用来临时保存标准输入。
同样标准输入也是可以重新定向的,请参考下面例子
# grep search-word
一般来说grep命令在给定文件中搜索字符串,以上命令把文件filename作为grep命令的标准输入,而不是从键盘输入。
前面曾经提到,系统为每一个打开的文件指定一个文件标识符以便系统对文件进行跟踪,那么默认的文件标识符是什么呢?答案是0,也就是标准输入,或者可以说从键盘输入。当然这个文件标识符也可以自己指定,请参考下面例子
#echo 123456789 >filename 把字符串写到文件filename中 #exec 3<>filename 把文件filename打开,并指定文件标识符为3 #read -n 4 <&3 从文件中读4个字符,句柄已经指到第四个字符末尾 #echo -n . >&3 在第5个字符处写一个点,覆盖第5个字符,-n表示不换行 #exec 3>&- 关闭文件标识符3
现在cat filename文件的结果就成了1234.6789
命令j<>filename表示把文件打开,并指明文件标识符为j
"&-"表示关闭文件标识符
有关关闭文件标识符的 *** 作请参考下面
n<&- 关闭输入文件标识符n 0<&-或<&- 关闭标准输入stdin n>&- 关闭输出文件标识符n 1>&-或>&-关闭标准输出stdout
另外还有一些其他命令,如下参考
2. :>filename 或者 >filename
表示把文件filename设置成空,也就是清空文件内容,如果文件不存在,则创建一个空文件,(等同于touch命令) :表示一个空输出,两个命令的唯一区别就是>filename不是在所有shell都可以正常工作的。
一个进程默认会打开标准输入、标准输出、错误输出三个文件描述符
文件描述符为0,小于号表示数据由文件流入命令
usage:
命令 <file
#加入输入重定向,对输入文件进行计数
wc -l </etc/passwd
文件描述符为1,大于号表述数据由命令流入文件
所以: echo "hello" >t.log 也可以写成 echo "hello" 1 >t.log
> 会把文件的内容清空,再输入到新的文件
>> 会把当前内容保持不变,然后在下一行进行追加
2> 错误重定向,如果当前命令产生了错误,会把错误重定向到文件中,而不会打印到屏幕
&> 无论内容正确还是错误都会把文件输出到文件中。
stderr的文件描述符为2,Unix程序会向stderr流中写入错误信息。
默认情况下, command >file 将stdout 重定向到 file, command <file 将stdin 重定向到 file。
如果希望 stderr 重定向到 file,可以这样写:
$ command 2>file
如果希望 stderr 追加到 file 文件末尾,可以这样写:
$ command 2>>file 2 表示标准错误文件(stderr)
如果希望将 stdout 和 stderr 合并后重定向到 file,可以这样写:
$ command >file 2>&1 或者 $ command >>file 2>&1
如果希望对 stdin 和 stdout 都重定向,可以这样写:
$ command <file1 >file2
command 命令将 stdin 重定向到 file1,将 stdout 重定向到 file2。
含义:将标准错误输出 重定向到 标准输出。
符号>&是一个整体,不可分开,分开后就不是上述含义了。
比如有些人可能会这么想:2是标准错误输入,1是标准输出,>是重定向符号,那么"将标准错误输出重定向到标准输出"是不是就应该写成"2>1"就行了?是这样吗? 如果是尝试过,你就知道2>1的写法其实是将标准错误输出重定向到名为"1"的文件里去了
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)