Chinaunix首页 | 论坛 | 博客
  • 博客访问: 364042
  • 博文数量: 93
  • 博客积分: 2855
  • 博客等级: 少校
  • 技术积分: 1012
  • 用 户 组: 普通用户
  • 注册时间: 2008-02-24 14:53
文章分类

全部博文(93)

文章存档

2011年(14)

2010年(73)

2008年(6)

分类:

2008-03-03 20:38:01

在llinux下,有个tac命令可将文本文件的文本行倒序排列输出,solaris下没有这种命令。

一时想不出方法,上了CU一问,得到专家指点,有下列方法可用:




1. 命令方法:
nl filename | sort -nr | cut -f2

这个方法很unix风格,使用多命令组合完成某种功能是典型的unix特点。


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

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


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

除非你熟悉PERL。


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

这个操作很经典,如果你能看懂这行命令中的sed函数的意义,那对sed就有基本的了解了。


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函数递归。
阅读(2293) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

yyygundam2014-11-17 17:54:27

博主的方法2还不完整,要改成

awk '{line[NR]=$0}END{for(i=NR;i>0;i--)print line[i]}' filename

既然是数组,line没有序号怎么知道要print那个元素,直接就回报错了。