Перенаправить вывод в массив bash
У меня есть файл, содержащий строку
ipAddress=10.78.90.137;10.78.90.149
Я хотел бы разместить эти два IP-адреса в массиве bash. Для этого я попробовал следующее:
n=$(grep -i ipaddress /opt/ipfile | cut -d'=' -f2 | tr ';' ' ')
Это приводит к извлечению значений в порядке, но по какой-либо причине размер массива возвращается как 1, и я замечаю, что оба значения идентифицируются как первый элемент в массиве. Это
echo ${n[0]}
возвращает
10.78.90.137 10.78.90.149
Как это исправить?
Спасибо за помощь!
Ответы
Ответ 1
Вам действительно нужен массив
bash
$ ipAddress="10.78.90.137;10.78.90.149"
$ IFS=";"
$ set -- $ipAddress
$ echo $1
10.78.90.137
$ echo $2
10.78.90.149
$ unset IFS
$ echo [email protected] #this is "array"
если вы хотите поместить в массив
$ a=( [email protected] )
$ echo ${a[0]}
10.78.90.137
$ echo ${a[1]}
10.78.90.149
@OP, относительно вашего метода: установите IFS в пространство
$ IFS=" "
$ n=( $(grep -i ipaddress file | cut -d'=' -f2 | tr ';' ' ' | sed 's/"//g' ) )
$ echo ${n[1]}
10.78.90.149
$ echo ${n[0]}
10.78.90.137
$ unset IFS
Кроме того, нет необходимости использовать столько инструментов. вы можете просто использовать awk или просто bash shell
#!/bin/bash
declare -a arr
while IFS="=" read -r caption addresses
do
case "$caption" in
ipAddress*)
addresses=${addresses//[\"]/}
arr=( ${arr[@]} ${addresses//;/ } )
esac
done < "file"
echo ${arr[@]}
Выход
$ more file
foo
bar
ipAddress="10.78.91.138;10.78.90.150;10.77.1.101"
foo1
ipAddress="10.78.90.137;10.78.90.149"
bar1
$./shell.sh
10.78.91.138 10.78.90.150 10.77.1.101 10.78.90.137 10.78.90.149
Gawk
$ n=( $(gawk -F"=" '/ipAddress/{gsub(/\"/,"",$2);gsub(/;/," ",$2) ;printf $2" "}' file) )
$ echo ${n[@]}
10.78.91.138 10.78.90.150 10.77.1.101 10.78.90.137 10.78.90.149
Ответ 2
Это работает:
n=(`grep -i ipaddress filename | cut -d"=" -f2 | tr ';' ' '`)
EDIT: (улучшенная, вложенная версия согласно Dennis)
n=($(grep -i ipaddress filename | cut -d"=" -f2 | tr ';' ' '))
Ответ 3
Вариант темы:
$ line=$(grep -i ipaddress /opt/ipfile)
$ saveIFS="$IFS" # always save it and put it back to be safe
$ IFS="=;"
$ n=($line)
$ IFS="$saveIFS"
$ echo ${n[0]}
ipAddress
$ echo ${n[1]}
10.78.90.137
$ echo ${n[2]}
10.78.90.149
Если в файле нет другого содержимого, вам может не понадобиться grep
, и вы можете прочитать его во всем файле.
$ saveIFS="$IFS"
$ IFS="=;"
$ n=$(</opt/ipfile)
$ IFS="$saveIFS"
Ответ 4
Решение Perl:
n=($(perl -ne 's/ipAddress=(.*);/$1 / && print' filename))
который проверяет и удаляет нежелательные символы за одну операцию.
Ответ 5
Вы можете сделать это, используя IFS
в bash
.
- Сначала прочитайте первую строку из файла.
- Seoncd преобразует это в массив с
=
в качестве делителя.
- Третий преобразовать значение в массив с помощью
;
в качестве разделителя.
Вот оно!!!
#!/bin/bash
IFS='\n' read -r lstr < "a.txt"
IFS='=' read -r -a lstr_arr <<< $lstr
IFS=';' read -r -a ip_arr <<< ${lstr_arr[1]}
echo ${ip_arr[0]}
echo ${ip_arr[1]}