Другое решение вышеупомянутой проблемы - установить каждую строку в переменную, вызвать функцию с переменными, обозначенными буквальным знаком доллара \$
. Затем в функции используйте eval
для чтения переменной и вывода, как ожидается.
#!/usr/bin/ksh
myFunction()
{
eval string1="$1"
eval string2="$2"
eval string3="$3"
echo "string1 = ${string1}"
echo "string2 = ${string2}"
echo "string3 = ${string3}"
}
var1="firstString"
var2="second string with spaces"
var3="thirdString"
myFunction "\${var1}" "\${var2}" "\${var3}"
exit 0
Выходные данные тогда:
string1 = firstString
string2 = second string with spaces
string3 = thirdString
Пытаясь решить аналогичную проблему, я столкнулся с проблемой UNIX, полагая, что мои переменные разделены пробелом. Я пытался передать строку с разделителем в функцию, awk
чтобы установить ряд переменных, которые позже использовались для создания отчета. Сначала я попробовал решение, опубликованное ghostdog74, но не смог заставить его работать, так как не все мои параметры передавались в кавычках. После добавления двойных кавычек к каждому параметру он начал функционировать как ожидалось.
Ниже приведено состояние «до» моего кода и полностью функционирует после состояния.
До - неработающий код
#!/usr/bin/ksh
#*******************************************************************************
# Setup Function To Extract Each Field For The Error Report
#*******************************************************************************
getField(){
detailedString="$1"
fieldNumber=$2
# Retrieves Column ${fieldNumber} From The Pipe Delimited ${detailedString}
# And Strips Leading And Trailing Spaces
echo ${detailedString} | awk -F '|' -v VAR=${fieldNumber} '{ print $VAR }' | sed 's/^[ \t]*//;s/[ \t]*$//'
}
while read LINE
do
var1="$LINE"
# Below Does Not Work Since There Are Not Quotes Around The 3
iputId=$(getField "${var1}" 3)
done<${someFile}
exit 0
После - функциональный код
#!/usr/bin/ksh
#*******************************************************************************
# Setup Function To Extract Each Field For The Report
#*******************************************************************************
getField(){
detailedString="$1"
fieldNumber=$2
# Retrieves Column ${fieldNumber} From The Pipe Delimited ${detailedString}
# And Strips Leading And Trailing Spaces
echo ${detailedString} | awk -F '|' -v VAR=${fieldNumber} '{ print $VAR }' | sed 's/^[ \t]*//;s/[ \t]*$//'
}
while read LINE
do
var1="$LINE"
# Below Now Works As There Are Quotes Around The 3
iputId=$(getField "${var1}" "3")
done<${someFile}
exit 0