重定向和管道符
重定向和管道符:
1.重定向
程序 = 指令 + 数据
命令 变量
在程序中,数据如何输入?如何输出?
数据输入:键盘--标准输入,但并不是唯一输入方式;
--stdin
echo "123456" | passwd --stdin "username"
例如:功能添加用户 useradd.sh txt文本文档1000个用户
./useradd.sh a
./useradd.sh b
...
./useradd.sh < user.txt
while line;do
循环体 $line
done < /etc/passwd
数据输出:显示器--标准输出,但并不是唯一输出方式
ls /etc/ > a.txt
fd 文件标识符 0-9 相当于给文件分类;
0 1 2被定义的标识符
3-9未被定义的标识符
0--标准输出
1--标准输入
2--错误输入输出(标准错误)
常见重定向符号
1.标准输出
> 覆盖重定向
>> 追加重定向
set -C 关闭覆盖重定向
>| 强制重定向
2.标准输入
<
tr 替换文件内容
tr set1[set2] < file.txt
tr abc ABC /etc/passwd
tr abc ABC /etc/passwd > /etc/passwd
将passwd文件中的a、b、c替换成A、B、C
<<
多行数据同时输入
cat >>a.txt<<EOF
>11
>2
>3
>EOF
3.错误输出
2> 2>>
/dev/null 黑洞文件(删除)
/dev/zero
ls /etc/ > /dev/null 2> /dev/null——
&> &>> == 2&>1 |=
ls /etc/ &> /dev/null<————
扩展:不需要输出内容,只需要输出状态;
ls /etc/ > /dev/null
if[$?(命令执行状态) -eq 0];then
循环体
fi
ls > /dev/null 2>dev/null
2.管道-tee
command1|command2|command3|...
前一个命令的执行结果交给后一个命令来执行;
【Linux思想:结合小功能实现大功能】
free -m|grep "^Mem"|cut -d'' -f19
free -m|grep "^Mem"|awk '{print $3}'
free【范围】-name ab* -type f -perm 600 -mtime +7|xargs rm -rf
tee[option]...屏幕上输出一次,然后保存一次(一路输入,两路输出)
tee /tmp/tee.out //如果没有文件,会创建,默认如果文件存在有内容,会覆盖
练习:
1.将/etc/passwd文件中的前5行内容转换为大写后保存至/tmp/passwd.out文件中
head -5 /etc/passwd | tr [a-z][A-Z] > /tmp/passwd.out
2.将登录至当前系统上的用户信息汇总的后3位信息转换为大写后保存至/tmp/who.out文件中
who | tail -3 | cut -d'' -f1 | tr [[:lower:]] [[:upper:]] | tree /tmp/who.out
tail——查看文件尾部多少行(默认为10行)
-n tail -(n)5 /etc/passwd
-f 实时查看文件更新内容
tial -f /var/log/message
sleep 等待多长时间后再向下执行
head——查看文件头部多少行(默认10行)
-n # 前#行,简写-#
取10-20行:head -20 /etc/passwd | tail -10
文本处理工具-wc,cut,sort,uniq
wc 统计文本中的字符个数
wc filename
行数 字符个数 文件大小(字节) 文件名
cut
用来做文件分隔
-d 指定分隔符(delimiter)
-f 指定提取哪一列
-f2
-f1,3
-f1-3
--output-delimiter='xx'
【cut的局限性:1、-d指定分隔符,不能同时指定多个;2、不能做高级的格式化输出】
sort 排序命令,默认查看第一个字符(包括数字字母以及空格和特殊符号),以ASCII码来排序 (大小写不是)
-r 逆序
-u 去掉重复
-n 按数字排序
-t -k 指定分隔符以及按照哪个区间排序
uniq 去除重复内容
连续且相同的命令,才被视为重复
建议,先排序,后去重
-c 统计某些字符重复次数
sort filename|uniq -c