Как изолировать цитируемый текст из файла в переменную оболочки? - PullRequest
0 голосов
/ 20 мая 2011

Как изолировать цитируемый текст из файла в переменную оболочки?
Также: как игнорировать строки, начинающиеся с '#'?

Допустим, у меня есть текстовый файл

8723 "full name" "more data here"
#5002 "another name" "bla bla bla"
7129 "single" blablabla
3910 noquote "bla bla bla"

и я хочу написать скрипт, который выполняет

#!/bin/sh
myscript <KEY> "<FULL NAME>" "<MORE DATA>"

для каждой строки в текстовом файле.
Если это облегчает задачу, можно предположить, что FULLNAME и MOREDATA в текстовом файле всегда заключены в кавычки, даже если они состоят из одного слова.


Я попробовал простое

#!/bin/sh
while read key name extra
do
    echo "myscript $key \"$name\" -- \"$extra\""
    #myscript $key "$name" "$extra"
done < list.txt

но он не группирует значение внутри кавычек в одной переменной оболочки.
Выход

myscript 8723 ""full" -- "name" "more data here""
myscript #5002 ""another" -- "name" "bla bla bla""
myscript 7129 ""single"" -- "blablabla"
myscript 3910 "noquote" -- ""bla bla bla""

Вместо этого я хотел бы получить

myscript 8723 "full name" -- "more data here"
myscript 7129 "single" -- "blablabla"
myscript 3910 "noquote" -- "bla bla bla"

Конечно, я могу добавить myscript к каждой строке исходного текстового файла и сделать этот файл скриптом или написать C программу для этого ...

Ответы [ 2 ]

1 голос
/ 20 мая 2011
#!/bin/sh
while read key name extra
do
    eval myscript $key $name $extra
done <(grep -v "^#" list.txt)
1 голос
/ 20 мая 2011
sed -e '/^[^#]/s/^/myscript /' list.txt

РЕДАКТИРОВАТЬ: Чтобы запустить его:

sed -e '/^[^#]/s/^/myscript /' list.txt | bash
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...