Я хочу сгенерировать команду SQOOP, которая добавляется некоторой переменной, например CUSTOM_PARAMS
. Я определил переменную в файле: скажем hi.cfg
Как избежать символов одиночной кавычки в подстановке команд bash
Переменная имеет некоторые одинарные кавычки, например, «orc».
cat hi.cfg CUSTOM_PARAMS="--query select * from blah..blah where \$CONDITIONS --split-by blah --create-hcatalog-table --hcatalog-external-table --hcatalog-storage-stanza stored as 'orc' --compress --compression-codec 'snappy' --fields-terminated-by '|' -m 5 --target-dir /any/dir"
Когда я источник в файл на командной строке и не повторить это дает мне точно, Что написано там что выглядит правильно.
source hi.cfg echo "$CUSTOM_PARAMS" --query select * from blah..blah where $CONDITIONS --split-by blah --create-hcatalog-table --hcatalog-external-table --hcatalog-storage-stanza stored as 'orc' --compress --compression-codec 'snappy' --fields-terminated-by '|' -m 5 --target-dir /any/dir
Но когда я называю это из сценария оболочки, как показано ниже:
cat hi.sh echo "Generating Sqoop Command" source $HOME/hi.cfg echo "${CUSTOM_PARAMS}" SQOOP_COMMAND="SQOOP statement : sqoop import blah blah "$CUSTOM_PARAMS"" echo $SQOOP_COMMAND
Символ * в переменной была обработана как команда:
sh hi.sh Generating Sqoop Command --query select * from blah..blah where $CONDITIONS --split-by blah --create-hcatalog-table --hcatalog-external-table --hcatalog-storage-stanza stored as 'orc' --compress --compression-codec 'snappy' --fields-terminated-by '|' -m 5 --target-dir /any/dir SQOOP statement : sqoop import blah blah --query select 0 00 000000_0 000073_0 000103_0 02 09.txt 1 from blah..blah where $CONDITIONS --split-by blah --create-hcatalog-table --hcatalog-external-table --hcatalog-storage-stanza stored as 'orc' --compress --compression-codec 'snappy' --fields-terminated-by '|' -m 5 --target-dir /any/dir
Мне нужно запустить инструкцию SQOOP позже в скрипте и попробовать несколько вариантов, но не помогло. Я также попытался \*
, но не помогло, она выводит:
Generating Sqoop Command --query select \* from blah..blah where $CONDITIONS --split-by blah --create-hcatalog-table --hcatalog-external-table --hcatalog-storage-stanza stored as 'orc' --compress --compression-codec 'snappy' --fields-terminated-by '|' -m 5 --target-dir /any/dir SQOOP statement : sqoop import blah blah --query select \* from blah..blah where $CONDITIONS --split-by blah --create-hcatalog-table --hcatalog-external-table --hcatalog-storage-stanza stored as 'orc' --compress --compression-codec 'snappy' --fields-terminated-by '|' -m 5 --target-dir /any/dir`
Спасибо, тонна Janos сейчас работает :) –