linux中如何把多行数据变为一列数据

1、测试数据

root@PC1:/home/test2# ls
test.txt
root@PC1:/home/test2# cat test.txt   ## 测试数据
a 3 5 d
s g e z

 

2、sed 实现

root@PC1:/home/test2# ls
test.txt
root@PC1:/home/test2# cat test.txt
a 3 5 d
s g e z
root@PC1:/home/test2# sed 's/ /\n/g' test.txt
a
3
5
d
s
g
e
z

 

3、cat + tr实现

root@PC1:/home/test2# ls
test.txt
root@PC1:/home/test2# cat test.txt
a 3 5 d
s g e z
root@PC1:/home/test2# cat test.txt | tr " " "\n"
a
3
5
d
s
g
e
z

 

4、xargs实现

root@PC1:/home/test2# ls
test.txt
root@PC1:/home/test2# cat test.txt
a 3 5 d
s g e z
root@PC1:/home/test2# cat test.txt | xargs -n 1
a
3
5
d
s
g
e
z

 

5、awk实现

root@PC1:/home/test2# ls
test.txt
root@PC1:/home/test2# cat test.txt
a 3 5 d
s g e z
root@PC1:/home/test2# awk '{gsub(" ","\n"); print $0}' test.txt
a
3
5
d
s
g
e
z

 

root@PC1:/home/test2# ls
test.txt
root@PC1:/home/test2# cat test.txt
a 3 5 d
s g e z
root@PC1:/home/test2# awk 'BEGIN{RS = " "} {print $0}' test.txt
a
3
5
d
s
g
e
z

root@PC1:/home/test2# awk 'BEGIN{RS = " "} {print $0}' test.txt | sed '$d'
a
3
5
d
s
g
e
z

 

6、测试数据

root@PC1:/home/test2# ls
test.txt
root@PC1:/home/test2# cat test.txt
a35d
sgez

 

7、sed + awk实现

root@PC1:/home/test2# ls
test.txt
root@PC1:/home/test2# cat test.txt
a35d
sgez
root@PC1:/home/test2# cat test.txt | sed 's/./&\n/g'
a
3
5
d

s
g
e
z

root@PC1:/home/test2# cat test.txt | sed 's/./&\n/g' | awk NF
a
3
5
d
s
g
e
z

 

root@PC1:/home/test2# ls
test.txt
root@PC1:/home/test2# cat test.txt
a35d
sgez
root@PC1:/home/test2# sed 's/./&\n/g' test.txt
a
3
5
d

s
g
e
z

root@PC1:/home/test2# sed 's/./&\n/g' test.txt | sed '/^[\t ]*$/d'
a
3
5
d
s
g
e
z

 

8、awk实现

root@PC1:/home/test2# ls
test.txt
root@PC1:/home/test2# cat test.txt
a35d
sgez
root@PC1:/home/test2# awk -F "" '{for(i = 1; i <= NF; i++) printf("%s", $i"\n")}' test.txt
a
3
5
d
s
g
e
z

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。