Chinaunix
标题:
关于某些动态刷新命令的管道输出问题。
[打印本页]
作者:
dwolf
时间:
2007-12-14 14:39
标题:
关于某些动态刷新命令的管道输出问题。
有很多命令是动态刷新的交互式命令,如systat -if 1
在用管道systat -if 1 >>stlog 输出到文本以后,会出现格式上的偏差,例:
---------
may be a binary file. See it anyway?
ESC[1;59r^@^@^@^@^@ESC[m^@^@ESC[?7hESC[HESC[J^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@ESC[1;21H^@^@^@^@^@/0 /1 /2 /3 /4 /5 /6 /7 /8 /9 /10^MESC[B^@^@ Load Average^MESC[2B^@^@ Interface Traffic Peak TotalESC[2;21H^@^@^@^@^@>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>ESC[5;13H^@^@^@^@^@lo0 in 0.000 KB/s 0.000 KB/s 4.219 KBESC[6;18H^@^@^@^@^@out 0.000 KB/s 0.000 KB/s 4.219 KBESC[8;12H^@^@^@^@^@fxp2 in 0.000 KB/s 0.000 KB/s 3.684 GBESC[9;18H^@^@^@^@^@out 0.000 KB/s 0.000 KB/s 3.929 GBESC[11;12H^@^@^@^@^@fxp1 in 0.000 KB/s 0.000 KB/s 3.948 GBESC[12;18H^@^@^@^@^@out 0.000 KB/s 0.000 KB/s 3.613 GBESC[14;12H^@^@^@^@^@fxp0 in 0.000 K
。。。。。
-----------
完全和直接执行命令看到的屏幕内容不一样,另外执行管道以后需要按ctl+c才能终止,请问谁有好的办法?
作者:
dwolf
时间:
2007-12-14 14:49
呵呵,想了个办法
less -f stlog | sed 's/^@//'
但是如果我用cond去定期执行的话,因为是交互命令,按Q退出,我只好sleep 2 然后kill 进程,谁有更好的办法?
作者:
dwolf
时间:
2007-12-21 16:23
但是还有个问题,less -f stlog | sed 's/^@//' 打印到屏幕是正常了,重定向到文本直接less看还是有问题
作者:
dwolf
时间:
2007-12-21 16:25
谁有好的解决办法吗?
作者:
dwolf
时间:
2007-12-26 13:09
顶下
欢迎光临 Chinaunix (http://bbs.chinaunix.net/)
Powered by Discuz! X3.2