linux系統中批量提取指定列的數據


linux系統中批量提取指定列的數據。

1、測試數據

[root@centos79 test]# cat a.txt
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18
03 0f 0t 0s 0g 0y 0a 0d 0e 0n 07 03 0a 0g 0w 0z 0n 0k
04 0s 03 0d 0i 0e 0w 0g 0w 0u 08 0s 0d 0e 0a 0v 0m 0p

 

2、提取 3,5,7,8,9,15,17列

[root@centos79 test]# ls
a.txt  cols  result
[root@centos79 test]# cat a.txt
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18
03 0f 0t 0s 0g 0y 0a 0d 0e 0n 07 03 0a 0g 0w 0z 0n 0k
04 0s 03 0d 0i 0e 0w 0g 0w 0u 08 0s 0d 0e 0a 0v 0m 0p
[root@centos79 test]# cat cols
3
5
7
8
9
15
17
[root@centos79 test]# cat result
[root@centos79 test]# for i in `cat cols`; do paste result <(cut -d " " -f $i a.txt ) > tmp && mv tmp result; done
[root@centos79 test]# cat result
        03      05      07      08      09      15      17
        0t      0g      0a      0d      0e      0w      0n
        03      0i      0w      0g      0w      0a      0m

 

3、awk提取

[root@centos79 test]# ls
a.txt  cols  result
[root@centos79 test]# cat a.txt
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18
03 0f 0t 0s 0g 0y 0a 0d 0e 0n 07 03 0a 0g 0w 0z 0n 0k
04 0s 03 0d 0i 0e 0w 0g 0w 0u 08 0s 0d 0e 0a 0v 0m 0p
[root@centos79 test]# cat cols
3
5
7
8
9
15
17
[root@centos79 test]# cat result
[root@centos79 test]# for i in $(cat cols ); do paste result <(awk -v a=$i '{print $a}' a.txt ) > tmp && mv tmp result; done
[root@centos79 test]# cat result
        03      05      07      08      09      15      17
        0t      0g      0a      0d      0e      0w      0n
        03      0i      0w      0g      0w      0a      0m

 

4、while語句

[root@centos79 test]# ls
a.txt  cols  result
[root@centos79 test]# cat a.txt
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18
03 0f 0t 0s 0g 0y 0a 0d 0e 0n 07 03 0a 0g 0w 0z 0n 0k
04 0s 03 0d 0i 0e 0w 0g 0w 0u 08 0s 0d 0e 0a 0v 0m 0p
[root@centos79 test]# cat cols
3
5
7
8
9
15
17
[root@centos79 test]# cat result
[root@centos79 test]# cat cols | while read i; do paste result <(cut -d " " -f $i a.txt ) > tmp && mv tmp result ; done
[root@centos79 test]# cat result
        03      05      07      08      09      15      17
        0t      0g      0a      0d      0e      0w      0n
        03      0i      0w      0g      0w      0a      0m

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM