1.功能:合并文件的列
2.用法:paste [参数] 文件
3.参数:
-d, --delimiters 指定间隔符,
-s, --serial 将多行数据合并成多列
4.例子
选取/etc/passwd文件的第一列和最后一列作为原始数据,使用paste命令进行测试,首先要从/etc/passwd文件中将第一列和最后一列提取出来:
[ ~]$ cat /etc/passwd |awk -F ":" '{print $1}'>user_name.txt
[ ~]$ cat /etc/passwd |awk -F ":" '{print $NF}'>user_login.txt
[ ~]$ head user_*#查看文件内容
例1:合并user_name,user_login两列
[ ~]$ paste user_name.txt user_login.txt|head -5
root /bin/bash
bin /sbin/nologin
daemon /sbin/nologin
adm /sbin/nologin
lp /sbin/nologin
指定分隔符为“,”
[ ~]$ paste -d "," user_name.txt user_login.txt|head -5
root,/bin/bash
bin,/sbin/nologin
daemon,/sbin/nologin
adm,/sbin/nologin
lp,/sbin/nologin
例2:行转列
文件的行转列,一个文件为1行。
一个文件行转列:
[ ~]$ paste -s user_name.txt
root bin daemon adm lp sync shutdown halt mail uucp operator games gopher ftp nobody dbus oprofile vcsa hsqldb saslauth postfix sshd mysql ntp
[ ~]$ paste -s user_name.txt |wc -l
1
两个文件行转列后进行和并:
[ ~]$ paste -s user_name.txt user_name.txt
root bin daemon adm lp sync shutdown halt mail uucp operator games gopher ftp nobody dbus oprofile vcsa hsqldb saslauth postfix sshd mysql ntp
root bin daemon adm lp sync shutdown halt mail uucp operator games gopher ftp nobody dbus oprofile vcsa hsqldb saslauth postfix sshd mysql ntp
[ ~]$ paste -s user_name.txt user_name.txt |wc -l
2
文件合并之后再行转列:
[ ~]$ paste -d user_name.txt user_name.txt|paste -s |wc -l
1