[英]store awk output in variable
我忽略了这段代码的问题是什么?
#! /bin/bash
File1=$1
for (( j=1; j<=3; j++ ))
{
output=$(`awk -F; 'NR=='$j'{print $3}' "${File1}"`)
echo ${output}
}
File1看起来像这样:
Char1;2;3;89
char2;9;6;66
char5;3;77;8
我想在每一行上提取循环字段3
所以结果会是
3
6
7
它应该是这样的:
#! /bin/bash
File1=$1
for (( j=1; j<=3; j++ ))
{
output=$(awk -F ';' 'NR=='$j' {print $3}' "${File1}")
echo ${output}
}
它在我的CentOS上运行良好。
-v
标志,则不能在awk脚本中使用bash变量 只是:
awk -F";" '{print $3}' "${file1}"
将完成您的整个脚本现在正在尝试做的事情。
更简单,使用cut
实用程序: cut -d';' -f3
cut -d';' -f3
将生成您正在查找的结果,其中-d
指定要使用的分隔符, -f
指定您要查找的字段/列(1索引)。
如果您只想从结构化文件中提取列,就像您拥有的那样,请使用cut
实用程序。
cut
将允许您指定数据中的分隔符( ;
)以及要提取的列(第3列)。
cut -d';' -f3 "$file1"
如果您想循环遍历此结果,请使用while
循环并逐个read
值:
cut -d';' -f3 "$file1" |
while read data; do
echo "data is $data"
done
您想要变量中的值,请执行此操作
var=$( cut -d';' -f3 "$file1" | tr '\n' ' ' )
tr '\\n' ' '
位用空格替换换行符,因此你可以得到3 6 77
作为字符串。
将它们放入数组中:
declare -a var=( $( cut -d';' -f3 "$file1" ) )
(这里不需要tr
)
然后,您可以访问${var[0]}
, ${var[1]}
等值。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.