linux 重定向命令

linux 重定向命令

标准输入,输出和错误
---------------------------------
文件文件 描述符
---------------------------------
输入文件—标准输入 0
输出文件—标准输出 1
错误输出文件—标准错误 2
---------------------------------

1.重定向

COMMAND_OUTPUT >
  2      # 将stdout重定向到一个文件. 
  3      # 如果这个文件不存在, 那就创建, 否则就覆盖. 
  4
  5      ls -lR > dir-tree.list
  6      # 创建一个包含目录树列表的文件. 
  7
  8   : > filename
  9      # >操作, 将会把文件"filename"变为一个空文件(就是size为0). 
 10      # 如果文件不存在, 那么就创建一个0长度的文件(与'touch'的效果相同). 
 11      # :是一个占位符, 不产生任何输出. 
 12
 13   > filename    
 14      # >操作, 将会把文件"filename"变为一个空文件(就是size为0). 
 15      # 如果文件不存在, 那么就创建一个0长度的文件(与'touch'的效果相同). 
 16      # (与上边的": >"效果相同, 但是某些shell可能不支持这种形式.)
 17
 18   COMMAND_OUTPUT >>
 19      # 将stdout重定向到一个文件. 
 20      # 如果文件不存在, 那么就创建它, 如果存在, 那么就追加到文件后边. 
 21
 22
 23      # 单行重定向命令(只会影响它们所在的行): 
 24      # --------------------------------------------------------------------
 25
 26   1>filename
 27      # 重定向stdout到文件"filename". 
 28   1>>filename
 29      # 重定向并追加stdout到文件"filename". 
 30   2>filename
 31      # 重定向stderr到文件"filename". 
 32   2>>filename
 33      # 重定向并追加stderr到文件"filename". 
 34   &>filename
 35      # 将stdout和stderr都重定向到文件"filename". 
 36
 37   M>N
 38     # "M"是一个文件描述符, 如果没有明确指定的话默认为1. 
 39     # "N"是一个文件名. 
 40     # 文件描述符"M"被重定向到文件"N". 
 41   M>&N
 42     # "M"是一个文件描述符, 如果没有明确指定的话默认为1. 
 43     # "N"是另一个文件描述符. 
 44
 45      #==============================================================================
 46
 47      # 重定向stdout, 一次一行. 
 48      LOGFILE=script.log
 49
 50      echo "This statement is sent to the log file, \"$LOGFILE\"." 1>$LOGFILE
 51      echo "This statement is appended to \"$LOGFILE\"." 1>>$LOGFILE
 52      echo "This statement is also appended to \"$LOGFILE\"." 1>>$LOGFILE
 53      echo "This statement is echoed to stdout, and will not appear in \"$LOGFILE\"."
 54      # 每行过后, 这些重定向命令会自动"reset". 

 58      # 重定向stderr, 一次一行. 
 59      ERRORFILE=script.errors
 61      bad_command1 2>$ERRORFILE       #  Error message sent to $ERRORFILE.
 62      bad_command2 2>>$ERRORFILE      #  Error message appended to $ERRORFILE.
 63      bad_command3                    #  Error message echoed to stderr,
 64                                      #+ and does not appear in $ERRORFILE.
 65      # 每行过后, 这些重定向命令也会自动"reset". 
 66      #==============================================================================
 67
 70   2>&1
 71      # 重定向stderr到stdout. 
 72      # 将错误消息的输出, 发送到与标准输出所指向的地方. 
 73
 74   i>&j
 75      # 重定向文件描述符i到j. 
 76      # 指向i文件的所有输出都发送到j. 
 77
 78   >&j
 79      # 默认的, 重定向文件描述符1(stdout)到j. 
 80      # 所有传递到stdout的输出都送到j中去. 
 81
 82   0< FILENAME
 83    < FILENAME
 84      # 从文件中接受输入. 
 85      # 与">"是成对命令, 并且通常都是结合使用. 
 86      #
 87      # grep search-word <filename
 88
 90   [j]<>filename
 91      # 为了读写"filename", 把文件"filename"打开, 并且将文件描述符"j"分配给它. 
 92      # 如果文件"filename"不存在, 那么就创建它. 
 93      # 如果文件描述符"j"没指定, 那默认是fd 0, stdin. 
 94      #
 95      # 这种应用通常是为了写到一个文件中指定的地方. 
 96      echo 1234567890 > File    # 写字符串到"File". 
 97      exec 3<> File             # 打开"File"并且将fd 3分配给它. 
 98      read -n 4 <&3             # 只读取4个字符. 
 99      echo -n . >&3             # 写一个小数点. 
100      exec 3>&-                 # 关闭fd 3.
101      cat File                  # ==> 1234.67890
102      # 随机访问. 
106   |
107      # 管道. 
108      # 通用目的处理和命令链工具. 
109      # 与">", 很相似, 但是实际上更通用. 
110      # 对于想将命令, 脚本, 文件和程序串连起来的时候很有用. 
111      cat *.txt | sort | uniq > result-file
112      # 对所有.txt文件的输出进行排序, 并且删除重复行. 
113      # 最后将结果保存到"result-file"中.

command > filename      把标准输出重定向到一个新文件中
command >> filename      把标准输出重定向到一个文件中(追加)
command 1 > fielname      把标准输出重定向到一个文件中
command > filename 2>&1    把标准输出和标准错误一起重定向到一个文件中
command 2 > filename     把标准错误重定向到一个文件中
command 2 >> filename     把标准输出重定向到一个文件中(追加)
command >> filename 2>&1   把标准输出和标准错误一起重定向到一个文件中(追加)
command < filename >filename2   把command命令以filename文件作为标准输入,以filename2文件作为标准输出
command < filename    把command命令以filename文件作为标准输入
command << delimiter   把从标准输入中读入,直至遇到delimiter分界符
command <&m    把文件描述符m作为标准输入
command >&m    把标准输出重定向到文件描述符m中
command <&-    把关闭标准输入

2.双向重定向

即在重定向数据到目标文件的同时,还要保证数据能够正常处理,使用tee命令。

tee [-a] file

  -a 往文件尾添加内容  

last | tee last_backup | cut -d " " -f 1 #tee相当于对last的结果备份了一次

补充:

Linux重定向是指修改原来默认的一些东西,对原来系统命令的默认执行方式进行改变,比如说简单的我不想看到在显示器的输出而是希望输出到某一文件中就可以通过Linux重定向来进行这项工作。

Linux默认输入是键盘,输出是显示器。你可以用重定向来改变这些设置。比如用wc命令的时候本来是要手动输入一篇文字来计算字符数的,用了重定向后可以直接把一个已经写好的文件用‘<’指向这条命令,就直接可以统计这个文件的字符数等了。输出也是一样,你可以把屏幕输出重定向到一个文件里,再到文件里去看结果。重定向操作符可以用来将命令输入和输出数据流从默认位置重定向到其他位置,其输入或输出数据流的位置称为句柄;常见的句柄有三种,当然句柄可以自行扩展,一般的OS都提供类似的功能。句柄 句柄代号 句柄描述

STDIN 0 键盘输入

STDOUT 1 输出信息到提示符窗口

STDERR 2 输出错误信息到提示符窗口

默认的 < 重定向输入操作符是 0,而默认的 > 重定向输出操作符是 1。键入 < 或 > 操作符之后,必须指定数据的读写位置,可以是文件名或其他现有的句柄。

要指定重定向到现有句柄,请使用与 & 字符,后面接要重定向的句柄号(即 &句柄号)。

例如,下面的命令可以将句柄 2(即 STDERR)重定向到句柄 1(即 STDOUT):2>&1

下表列出了可用于重定向输入和输出数据流的操作符:

Linux重定向操作符 功能描述

> 将命令输出写入文件或设备,而不是命令提示符或句柄

< 从文件而不是从键盘或句柄读入命令输入

>> 将命令输出添加到文件末尾而不删除文件中已有的信息

>& 将一个句柄的输出写入到另一个句柄的输入中

<& 从一个句柄读取输入并将其写入到另一个句柄输出中

| 从一个命令中读取输出并将其写入另一个命令的输入中;也称为管道操作符

现在我们回过头来看看上面的那条语句mysh > mylog.txt 2>&1就可明白:

> mylog.txt意思是将标准输出重定向到mylog.txt,等价于mysh 1> mylog.txt;

2 >& 1 意思是将错误输出重定向到句柄1标准输出;综合起来就是mysh命令执行过程中产生的标准输出和错误输出都会被重定向到mylog.txt中;

重定向的功能十分强大,有兴趣的可以去尝试各种不同的组合,看看前后位置变下会有什么结果?

某些时候我们可能并不希望记录什么标准输出或者是错误输出,那可以用mysh >null 2>null或者mysh >/dev/null 2>/dev/null;

I/O重定向详解

1、 基本概念(这是理解后面的知识的前提,请务必理解)

a、 I/O重定向通常与 FD有关,shell的FD通常为10个,即 0~9;

b、 常用FD有3个,为0(stdin,标准输入)、1(stdout,标准输出)、2(stderr,标准错误输出),默认与keyboard、monitor、monitor有关;

c、 用 < 来改变读进的数据信道(stdin),使之从指定的档案读进;

d、 用 > 来改变送出的数据信道(stdout, stderr),使之输出到指定的档案;

e、 0 是 < 的默认值,因此 < 与 0<是一样的;同理,> 与 1> 是一样的;

f、 在IO重定向 中,stdout 与 stderr 的管道会先准备好,才会从 stdin 读进资料;

g、 管道“|”(pipe line):上一个命令的 stdout 接到下一个命令的 stdin;

h、 tee 命令是在不影响原本 I/O 的情况下,将 stdout 复制一份到档案去;

i、 bash(ksh)执行命令的过程:分析命令-变量求值-命令替代(``和$( ))-重定向-通配符展开-确定路径-执行命令;

j、 ( ) 将 command group 置于 sub-shell 去执行,也称 nested sub-shell,它有一点非常重要的特性是:继承父shell的Standard input, output, and error plus any other open file descriptors。

k、 exec 命令:常用来替代当前 shell 并重新启动一个 shell,换句话说,并没有启动子 shell。使用这一命令时任何现有环境都将会被清除。exec 在对文件描述符进行操作的时候,也只有在这时,exec 不会覆盖你当前的 shell 环境。

2、 基本IO

cmd > file 把 stdout 重定向到 file 文件中;

cmd >> file 把 stdout 重定向到 file 文件中(追加);

cmd 1> fiel 把 stdout 重定向到 file 文件中;

cmd > file 2>&1 把 stdout 和 stderr 一起重定向到 file 文件中;

cmd 2> file 把 stderr 重定向到 file 文件中;

cmd 2>> file 把 stderr 重定向到 file 文件中(追加);

cmd >> file 2>&1 把 stderr 和 stderr 一起重定向到 file 文件中(追加);

cmd < file >file2 cmd 命令以 file 文件作为 stdin,以 file2 文件作为 stdout;

cat <>file 以读写的方式打开 file;

cmd < file cmd 命令以 file 文件作为 stdin;

cmd << delimiter Here document,从 stdin 中读入,直至遇到 delimiter 分界符。

3、 进阶IO

>&n 使用系统调用 dup (2) 复制文件描述符 n 并把结果用作标准输出;

<&n 标准输入复制自文件描述符 n;

<&- 关闭标准输入(键盘);

>&- 关闭标准输出;

n<&- 表示将 n 号输入关闭;

n>&- 表示将 n 号输出关闭;

上述所有形式都可以前导一个数字,此时建立的文件描述符由这个数字指定而不是缺省的 0 或 1。如:

... 2>file 运行一个命令并把错误输出(文件描述符 2)定向到 file。

... 2>&1 运行一个命令并把它的标准输出和输出合并。(严格的说是通过复制文件描述符 1 来建立文件描述符 2 ,但效果通常是合并了两个流。)

我们对 2>&1详细说明一下 :2>&1 也就是 FD2=FD1 ,这里并不是说FD2 的值 等于FD1的值,因为 > 是改变送出的数据信道,也就是说把 FD2 的 “数据输出通道” 改为 FD1 的 “数据输出通道”。如果仅仅这样,这个改变好像没有什么作用,因为 FD2 的默认输出和 FD1的默认输出本来都是 monitor,一样的!但是,当 FD1 是其他文件,甚至是其他 FD 时,这个就具有特殊的用途了。请大家务必理解这一点。

exec 0exec 1>outfilename # 打开文件outfilename作为stdout。

exec 2>errfilename # 打开文件 errfilename作为 stderr。

exec 0<&- # 关闭 FD0。

exec 1>&- # 关闭 FD1。

exec 5>&- # 关闭 FD5。

这样就完成了Linux重定向的学习。

相关推荐