我有一个shell脚本
#/bin/bash
var1=`cat log.json | grep "accountnumber" | awk -F ' ' '{print $1}'`
echo $varshell脚本的输出是:-
23466
283483
324932
87374我想匹配上面已经存储在另一个文件中的数字(下面是文件格式)并打印它的值。
23466=account-1
283483=account-2
324932=account-3
87374=account-4
127632=account-5
1324237=account-6
73642=account-7
324993284=account-8
.
.
4543454=account-200exapected输出
account-1
account-2
account-3
account-4发布于 2018-08-15 00:40:38
紧凑型单线解决方案可以是:
join -t "=" <(sort bf) <(sort fa) | cut -d '=' -f 2其中fa是包含bash脚本输出的文件,bf是bash格式的文件。
输出为:
account-1
account-2
account-3
account-4发布于 2018-08-15 00:15:23
#!/bin/bash
for var1 in $(awk -F ' ' '/accountnumber/{print $1}' log.json)
do
awk -F= '$1=="'"$var1"'"{print $2}' anotherfile
done有一段时间,有另一个几乎有效的答案,我认为它比我写的要圆滑得多。在大文件上可能也会更快/更高效。在这里它是固定的。
awk -F ' ' '/accountnumber/{print $1}' log.json \
| sort -n \
| join -t= - accountfile \
| cut -d= -f2https://stackoverflow.com/questions/51845603
复制相似问题