标准I/O和管道

t01c8d0a587f7a91802

input:输入读入数据

output:输出数据文件的

打开的文件都有一个fd: file descriptor (文件描述符)

ll /proc/$$/fd #查看fd

exec 8<>/data/hosts #指定fd

I/O重定向:该变默认位置

> #把标准输出重定向到文件(一个”>”是覆盖,”>>”是追加)

2> #把错误输出重定向到文件

&> #把所有输出重定向到文件

ls /error /etc >f1 2>f2 #把对的输出放到f1文件中错的输出放到f2文件中

() #提升命令输出的优先级

例如:ls /error /etc 2>&1 >all.log #不加()错误信息显示正确信息重定向到all.log

(ls /error /etc 2>&1) >all.log #家()先把错误信息重定向到all.log再把正确的追加进去

set –C 禁止将内容覆盖已有文件,但可追加

>| file 强制覆盖

set +C 允许覆盖

>> 原有内容基础上,追加内容

&> /dev/null #不显示输出结果

>文件名 #创建空文件夹

>>文件名 #文件名不重名的情况下创建空文件夹,重名译为追加

tr #替换和删除字符(文本处理命令)

tr ‘a-z’和[:upper:]不能混用,语法错误

 

-d #删除输入

-s #删除连续重复输入

-sc ‘a’ #除了a压缩(删除)连续重复输入,c表示取反

-dc ‘a\n’ #除了a删除所有输入回车

seq 1 10 #列出1到10以列的形式

hexdump #查看文件内容的机器码

cat #查看

cat  < file #吧file文件中的内容发送给cat相当于cat file

cat > filea <fileb #吧fileb文件中的内容重定向给filea

cat > file #单行重定向,回车一次写入一行,Ctrl+d结束(如果文件中有内容会被覆盖)

cat > file <<EOF #多行重定向,以EOF(end of file约定俗成的,也可以用其他字符 )结束

| #管道符,吧前一个命令的标准输出传送给下一个命令

错误输出默认不能通过管道转发,可用2>&1或者|&实现

|& #把标准输出和错误输出同时传输给下一个命令

echo {1 .. 100} | tr ‘ ’ ‘ +’ | bc #显示1到100的结果给tr,tr把空格替换成+的结果给bc命令实现计算1+2+3…. +100 。等同于seq -s + 100 | bc命令

命令1 | tee [-a] 文件名 | 命令2

把命令1的标准输出保存到文件中,作为命令2的输入,-a追加,否则覆盖

touch `openssl rand -base64 9 |tr ‘’’`.log生成指定字符的随机文件名

 

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/94701

(0)
老司机丨快上车老司机丨快上车
上一篇 2018-04-02 19:22
下一篇 2018-04-02 19:48

相关推荐

  • Homework_week4

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。       cp -a /etc/skel /home/tuser1       chmod 700 /home/tuser1 2、编辑/etc/group文件,添加组hadoop。       echo “ha…

    Linux笔记 2018-06-27
  • 在CentOS7上编译安装apache 2.4源码包,并启动此服务

    1 关闭firwalld systemctl stop firewalld systemctl disable firewalld 2 关闭SElinux setenforce 0 vim /etc/selinux/config 找到以SELINUX开头的那行,修改成SELINUX=disabled 以下就是脚本里的内容,执行就OK了 yum groupin…

    Linux笔记 2018-04-22
  • Linux上的文件管理类命令

    一、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。(1)目录管理命令——ls:列出指定目录下的内容格式:ls [OPTION]… [FILE]…-a:显示所有文件包括隐藏文件-A:显示除.和..之外的所有文件-l,–long:显示文件的详细属性信息-h:对文件大小进行单位换算,可能影响精度-d:查…

    Linux笔记 2018-05-19
  • Httpd基础

    Httpd基础

    2018-05-04
  • 用户管理

    用户管理 注意:用户是通过UID来确定身份的,比如root之所以为管理员就是因为root的UID是0。在centos6上系统用户是1-499,普通用户是500以上的;而在centos7上系统用户是1-999,普通用户是1000以上。系统用户默认不登录。 注意跟用户相关的命令只有管理员账户才有权限 需要用到的命令:useradd usermod userdel…

    Linux笔记 2018-04-08