Ще одне рішення вищезазначеного питання - встановити кожну рядок змінною, викликати функцію зі змінними, позначеними буквальним знаком долара \$
. Потім у функції використовуйте 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