# reverse order of lines (emulates "tac") #反转文章行的顺序(类似"tac" ) sed '1!G;h;$!d' # method 1 sed -n '1!G;h;$p' # method 2
说下method1原理,method2和它类似。
h copy pattern space to hold space.
流程如下
当读入第一行的时候,不匹配1!G,G不执行,然后执行h命令
将第一行的内容copy到了hold space。
不是最后一行,匹配$!d,执行d命令删除当前pattern space中第一行的内容,并读入下一行,并抑制默认输出
第二行匹配1!G,执行G命令,将hold space的内容附加到当前pattern space内容的后面,
也就是第一行附加在第二行的后面。
继续执行h命令,将当前pattern space的内容copy到hold space
执行到$!d,不是最后一行,就继续循环。
执行到了最后一行,$!d不执行,默认out。
这个循环就保证了前面一行的内容附加到后面一行的尾部,产生tac效果,对所有行做了反转顺序输出。