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

35 篇文章 0 订阅

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"表示处理完成每一行之后,多打印一个换行符。
  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值