linux上将文本行倒序输出的方法总结

转至: http://www.linuxpig.com/2010/10/linuxshangjiangwenbenxingdaoxushuchudefangfazongjie/



有下列方法:

1. 命令方法:
在llinux下,首先想到的就是 tac命令 ,可将文本文件的文本行倒序排列输出。

2. AWK方法:
awk '{line[NR]=$0}END{for(i=NR;i>0;i–)print line}' filename

这个利用了AWK的数组功能。

说明:END 操作是在所有都处理完成后的动作

3. PERL方法:
perl -e 'print reverse <>' filename

还是perl好用,perl处理文本真的很强悍。

4. SED方法
sed '1!G;h;$!d' filename

5. VI方法
vi指令 :g/^/m0

6. shell方法
#!/bin/bash

revread() {
local line
read line || return 0
revread
echo $line
}

revread

利用了shell编程中的函数递归。

如果文本行非常多,递归层次也将非常多,那么这个脚本会导致什么效果?

试过了才知道。与C程序不同,shell脚本的递归层次增加,不会导致所谓的“堆栈溢出”,但不断增加该shell的内存占用量,如果文本行足够多,可能会耗尽系统可用内存(在系统允许的情况下)。

我们使用递归时都知道,递归层次应得到有效控制,不能无限增加。这不仅是一个资源消耗问题,也是个运行效率问题。递归方法一般只用于递归层次非常有限,且代码用递归方法表示时逻辑更清晰的场合。


你可能感兴趣的:(shell,programming)