Linux shell:文本的按行逆序和字符串逆序


Linux shell:文本的按行逆序和字符串逆序

假定有以下文件:
qingsong@db2a:/tmp$ cat file.txt
abcde hello,world
12345!

按行逆序

即第一行和最后一行交换、第2行和倒数第2行交换,以些类推。

方法1,使用tac

tac命令是cat命令的反写,效果也正好相反,从最后一行开始打印文件
qingsong@db2a:/tmp$ tac file.txt
12345!
abcde hello,world

方法2,使用awk

qingsong@db2a:/tmp$ awk '{array[NR]=$0} END { for(i=NR;i>0;i--){print array[i];} }' file.txt
12345!
abcde hello,world
上面的方法是设置一个数组array,第n行放到array[n]中。处理完最后一行后,用for循环把数组倒着打印出来。

方法3,使用sed

qingsong@db2a:/tmp$ sed -n '1!G;h;$p' file.txt
12345!
abcde hello,world
这个利用了sed的pattern space和hold space,之前已经讲过
http://blog.csdn.net/qingsong3333/article/details/77512303


字符串逆序

把每一行的内容,都逆序输出

方法1,使用rev

rev命令专门用来逆序输出文件中每一行的内容:
qingsong@db2a:/tmp$ rev file.txt
dlrow,olleh edcba
!54321

方法2,使用awk

qingsong@db2a:/tmp$ awk '{ for(i=length($0);i>0;i--){printf substr($0,i,1)}; printf "\n"}' file.txt
dlrow,olleh edcba
!54321
先解释一下substr($0,i,1),这是抽取子串的函数,第一个参数为字符串,第二个参数表示从第i位开始抽取,第三个参数表示抽取的子串的长度,所以substr($0,i,1)表示取该行的第i个字符。for循环的作用就是从该行的最后一位,遍历到第一位,并打印该位置上的字符。后面的printf "\n"表示处理完成每一行之后,多打印一个换行符。

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