linux命令输出 linux命令输出log并打印

linux命令输出到屏幕的同时保存到文件tee用于把命令结果打印在屏幕上并同时保存到文件 。
tee用法
描述:从标准输入中读取并同时写入到标准输出和指定的文件上
选项:
-a,--append:不覆盖 , 而是追加输出到指定的文件中
-i,--ignore-interrupts:忽略中断信息
若指定的输出文件为'-',则再次输出到标准输出上
实例:
tee Example.txt #将标准输入中输入的内容同时输出到Example.txt和标准输出上
实践:
例如 ifconfig | tee ifconfig.log
查看iconfig.log
注:
标准输入一般有键盘和其它文件,标准输出有屏幕等 。tee只能进行标准输入的输出,对于错误输入是不能输出的 。
在调试脚本时,想要每个命令的执行过程都输出到屏幕或者文件中,以便后续查看,如何操作呢?首先脚本第一行要写为“#!/bin/b.sh -x” , 这样会把每个命令的执行记录都输出到屏幕 , 若还要输出到指定文件 , 要用到tee,但tee只能进行标准输入,对于标准输入和错误输入要用到下式:
./filename.sh 21 | tee output.log或者直接 bash -x ./filename.sh 21 | tee output.log
今天调试一个bash,要把屏幕的输出结果存到log文件中,开始输入$bash -x ./test.shlog 结果发现log里只存放了程序的执行结果,后来在cu的一篇帖子里?tid=264380highlight=bash得到了启发,bash -x的调试信息是输出到2号流中的 , 所以解决方案为bash -x ./test.sh 21 | tee log 想起以前要存放执行make的结果时也遇到类似问题,总结如下:
1、管道符的“I”的作用只是把前一个程序的标准输出流(stdout)的数据作为后一个程序的标准输入流stdin的数据,如不进行重定向,则其他输出流的信息是无法传给后面的程序的
2、屏幕得到的信息不一定是从程序的标准输出来的 , 也包括标准错误输出流stderr中的信息
3、有些程序(特别是象bash、make这样执行了其他程序的程序)的设计者为了省事,把一些正常情况的信息也放在stderr中输出(即使程序本身并无错误),而stdout用来输出被调用程序的执行时信息,造成了用户的误解简单编写了一下脚本 , 通过ssh登陆在命令行下运行正常,可是将脚本添加到crontab中就不正常 。想记录一下输出信息,分析一下错误原因 。将脚本通过使用info.log 重定向输出,结果发现一些在命令行下可以看到的文本信息没有记录到info.log文件中,研究了一下,那些输出估计是输出到了标准错误上 。
研究了一下通常添加命令后面几个输出含义
■ /dev/null 输出到空设备,表示丢掉输出信息 。
■ 21将输出到标准错误的信息输出到标准输出设备(通常是屏幕)有3个默认的i/o,
■ 0是标准输入 , 一般是键盘
■ 1是标准输出,一般是屏幕
■ 2是标准错误,有时候屏幕上可以看到,但是重定向的文件中看不到的就是它了
linux的ls命令的输出如何添加行号在 Linux 系统中,可以使用 ls 命令列出当前目录下linux命令输出的文件和目录 。如果您希望在 ls 命令的输出中添加行号,可以使用 nl 命令配合 ls 命令使用 。例如,您可以这样使用这两个命令:
ls | nl
这条命令会列出当前目录下的文件和目录 , 并在每一行的开头添加一个行号 。如果您只想显示文件,可以使用 -l 参数来更改 ls 命令的输出,例如:
ls -l | nl
这条命令只会列出当前目录下的文件,并且会显示每个文件的详细信息,包括权限、大小、时间等 。
需要注意的是,nl 命令的行号是从 1 开始的,如果您希望从其linux命令输出他数字开始编号,可以使用 -n 参数来指定行号的开始值 。例如,如果您希望从 5 开始编号,可以这样使用 nl 命令:
ls | nl -n 5
这条命令会从 5 开始编号,每一行的行号都比上一行多 1 。您还可以使用其他参数,来控制行号的格式和显示方式 。具体的用法可以参考 nl 命令的帮助文档,或者搜索相关资料 。
“linux print”命令是什么?printf 是linux 下的格式化输出命令 。
有点儿类似于python 和c 语言的printf 命令,但是应该没有c语言的那么强大. 。printf 命令常用于linux 下的awk 编程, 平时使用输出时用 echo 即可 。pintf 命令不能接受管道符参数,也不能之直接跟文件名, 但是可以跟系统命令执行的结果,如`df` 或者 $(cat /etc/passwd) 。
一、命令格式: printf'输出类型转义符' 输出内容 。
二、常用输出格式:
1、%ns :输出字符串; 输出n位的字符串linux命令输出;
2、 %ni:输出整数: 输出n位的整数;
3、%m.nf:输出浮点数: m位整数 和 n位小数;
三、常用转义符linux命令输出:
1、\t水平tab 键;
2、\v垂直tab 键;
3、\n换行;
4、\r回车, Enter键;
5、\f清除屏幕;
6、\b输出退格键;
7、\a输出警告声音 。
注意:
1. printf 命令默认输出结果没有换行符,需要手工添加\n 。
2. printf 命令后面不能接受管道符参数, 如:df| print'%s' 是错误的 。
3. print命令后面也不能直接跟文件名, 如: print '%5s'/etc/passwd是错误的 。
4. print命令后可以跟系统命令执行的结果, 如: print '%s'$(cat /etc/password)' 。
linux标准输入输出linux中有三种标准输入输出 , 分别是STDIN,STDOUT , STDERR,对应的数字是0,1,2 。
STDIN是标准输入,默认从键盘读取信息;
STDOUT是标准输出,默认将输出结果输出至终端;
STDERR是标准错误,默认将输出结果输出至终端 。
由于STDOUT与STDERR都会默认显示在终端上,为了区分,就有了编号的0 , 1,2的定义,用1表示STDOUT,2表示STDERR 。
21,指将标准输出、标准错误指定为同一输出路径
举栗子:
eg1:cat filetest 21 END-------建立filetest文件,当输入遇到END时,退出
eg2:
【linux命令输出 linux命令输出log并打印】 1、以普通用户执行find /etc -name passwd命令,默认会将命令的执行结果(STDOUT)与错误信息(STDERR)都输出至终端显示器 。
2、执行find /etc -name passwd find.out 2find.err,会将STDOUT与STDERR分别存放至find.out和find.err中 。该命令也可以写成下面三种形式
find /etc -name passwd 1find.out 2find.err
find /etc -name passwd 2find.err find.out
find /etc -name passwd 2find.err 1find.out
3、若要将所有标准输出及标准错误都输出至文件 , 可用表示全部1和2的信息,eg:
find /etc -name passwd find.all 或 find /etc -name passwd find.all 21
4、21 ---标准错误重新定向到标准输出
5、用法:find /etc -name passwd 21 |less
可分解成
find /etc -name passwd表示前面的命令放到后台执行 。
21 |less 表示将标准错误重定向至标准输出,并用less进行分页显示
linux命令输出的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux命令输出log并打印、linux命令输出的信息别忘了在本站进行查找喔 。

    推荐阅读