Как изолировать цитируемый текст из файла в переменную оболочки?
Также: как игнорировать строки, начинающиеся с '#'
?
Допустим, у меня есть текстовый файл
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
программу для этого ...