Подтвердить что ты не робот

Перенаправить вывод в массив 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

Как это исправить?

Спасибо за помощь!

4b9b3361

Ответ 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]}