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.txt12345!
abcde hello,world
上面的方法是设置一个数组array,第n行放到array[n]中。处理完最后一行后,用for循环把数组倒着打印出来。
方法3,使用sed
qingsong@db2a:/tmp$ sed -n '1!G;h;$p' file.txt12345!
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.txtdlrow,olleh edcba
!54321
先解释一下substr($0,i,1),这是抽取子串的函数,第一个参数为字符串,第二个参数表示从第i位开始抽取,第三个参数表示抽取的子串的长度,所以substr($0,i,1)表示取该行的第i个字符。for循环的作用就是从该行的最后一位,遍历到第一位,并打印该位置上的字符。后面的printf "\n"表示处理完成每一行之后,多打印一个换行符。