簡體   English   中英

如何比較2個文件並僅打印出選定的信息?

[英]How to compare 2 files and print out only selected info?

我正在嘗試比較這兩個文件,並且只打印出我需要的作為期望輸出的內容。

File1: 
012345:x:9012345:9012345:John Smith:/home/bin/bash
543210:x:9876543:9876543:Troy Denver:/home/bin/bash
111111:x:9898989:9898989:Mathew Moore:/home/bin/bash
222222:x:0101010:0101010:Chuck Maxwell:/homebin/bash
333333:x:1212121:1212121:Bob Evans:/home/bin/bash

File2:
333333 ALL=(ALL) NOPASSWD: ALL
543210 ALL=(ALL) NOPASSWD: ALL
222222 ALL=(ALL) NOPASSWD: ALL

Desired Output: 
333333 Bob Evans
543210 Troy Denver
222222 Chuck Maxwell

這就是我所做的

readarray num1 < file1 | awk -F'[ ]' '{print $1}'
while read -r $num1;
        do grep "$num1" file2
        echo "$num1" | awk -F':' '{print $1,$5}'

done < file3.txt

使用 GNU 連接、排序、sed 和 bash:

join -j 1 -t : <(sort File1) <(sed 's/ /:/' File2 | sort) -o 1.1,1.5 | sed 's/:/ /'

輸出:

222222 Chuck Maxwell
333333 Bob Evans
543210 Troy Denver

參見: man join

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM