Shell 标准输入、输出和错误
防伪码:桃花潭水深千尺,不及汪伦送我情。
文件描述符(fd):文件描述符是一个非负整数,在打开现存文件或新建文件时,内核会返回一个
文件描述符,读写文件也需要使用文件描述符来访问文件。
内核为每个进程维护该进程打开的文件记录表。文件描述符只适于 Unix、Linux 操作系统。
8. 1 标准输入、输出和错误
文件描述符 描述 映射关系
0 标准输入,键盘 /dev/stdin -> /proc/self/fd/0
1 标准输出,屏幕 /dev/stdout -> /proc/self/fd/1
2 标准错误,屏幕 /dev/stderr -> /proc/self/fd/2
8.2 重定向符号
符号 描述
> 符号左边输出作为右边输入(标准输出)
>> 符号左边输出追加右边输入
< 符号右边输出作为左边输入(标准输入)
<< 符号右边输出追加左边输入
& 重定向绑定符号
输入和输出可以被重定向符号解释到 shell。
shell 命令是从左到右依次执行命令。
下面 n 字母是文件描述符。
8.3 重定向 输出
1)覆盖输出
一般格式:[n]>word
如果 n 没有指定,默认是 1
示例:
打印结果写到文件:echo "test" > a.txt
当没有安装 bc 计算器时,错误输出结果写到文件:echo "1 + 1" |bc 2> error.log
2)追加重定向输出
一般格式:[n]>>word
如果 n 没有指定,默认是 1
示例:
打印结果追加到文件:echo "test" >> a.txt
当没有安装 bc 计算器时,错误输出结果追加文件:echo "1 + 1" |bc 2> error.log
8.4 4 重定向输入
一般格式:[n]<word
如果 n 没有指定,默认是 0
示例:
a.txt 内容作为 grep 输入:grep "test" --color < a.txt
8.5 5 重定向标准输出和标准错误
1)覆盖重定向标准输出和标准错误
两种格式重定向标准输出和标准错误:
&>word 和>&word 等价于>word 2>&1
&将标准输出和标准输入绑定到一起,重定向 word 文件。
示例:
当不确定执行对错时都覆盖到文件:echo "1 + 1" |bc &> error.log
当不确定执行对错时都覆盖到文件:echo "1 + 1" |bc > error.log 2>&1
2)追加标准输出和标准错误
追加格式:&>>word 等价于>>word 2>&1
当不确定执行对错时都追加文件:echo "1 + 1" |bc &>> error.log
将标准输出和标准标准输入追加重定向到 word:
<<[-]word
here-document
delimiter
从当前 shell 读取输入源,直到遇到一行只包含 delimiter 终止,内容作为标准输入。
将 eof 标准输入作为 cat 标准输出再写到 a.txt:
# cat <<eof
123
abc
eof
123
abc
# cat > a.txt << eof
> 123
> abc
> eof
8.6 重定向到 空设备
/dev/null 是一个空设备,向它写入的数组都会丢弃,但返回状态是成功的。与其对应的还有一个
/dev/zero 设备,提供无限的 0 数据流。
在写 Shell 脚本时我们经常会用到/dev/null 设备,将 stdout、stderr 输出给它,也就是我们不想
要这些输出的数据。
通过重定向到/dev/null 忽略输出,比如我们没有安装 bc 计算器,正常会抛出没有发现命令:
# echo "1 + 1" |bc >/dev/null 2>&1
这就让标准和错误输出到了空设备。
忽略标准输出:
# echo "test" >/dev/null
忽略错误输出:
# echo "1 + 1" |bc 2>/dev/null
d 8.7 read 命令
read 命令从标准输入读取,并把输入的内容复制给变量。
命令格式: read [-ers] [-a array] [-d delim] [-i text] [-n nchars] [-N nchars] [-p
prompt] [-t timeout] [-u fd] [name ...]
-e 在一个交互 shell 中使用 readline 获取行
-r 不允许反斜杠转义任何字符
-s 隐藏输入
-a array 保存为数组,元素以空格分隔
-d delimiter 持续读取直到遇到 delimiter 第一个字符退出
-i text 将 test 文本作为
-n nchars 读取 nchars 个字符返回,而不是等到换行符
-N nchars 读取 nchars 个字符返回,除非遇到文件结束符或超时,其他分隔符都被忽略
-p prompt 提示信息
-t timeout 等待超时时间,秒
-u fd 指定文件描述符号码作为输入,默认是 0
name 变量名
示例:
获取用户输入保存到变量:
# read -p "Please input your name: " VAR
Please input your name: lizhenliang
# echo $VAR
lizhenliang
用户输入保存为数组:
# read -p "Please input your name: " -a ARRAY
Please input your name: a b c
# echo ${ARRAY[*]}
a b c
遇到 e 字符返回:
# read -d e VAR
123
456
e
# echo $VAR
123 456
从文件作为 read 标准输入:
# cat a.txt
adfasfd
# read VAR < a.txt
# echo $VAR
adfasfd
while 循环读取每一行作为 read 的标准输入:
# cat a.txt |while read LINE; do echo $LINE; done
123
abc
分别变量赋值:
# read a b c
1 2 3
# echo $a
1
# echo $b
2
# echo $c
3
# echo 1 2 3 | while read a b c;do echo "$a $b $c"; done
1 2 3
谢谢观看,真心的希望能帮到您!
本文出自 “一盏烛光” 博客,谢绝转载!
更多建议: