0

下面是一个用于获取 2 个输入参数值的 shell 脚本,

  1. asd#@#g#@#h#@#j@#@k

  2. 候选人ID

这给了我们输出

string0 asd
string1 g
string2 h 
.
.
.

candidateid

.
.
.

(& 然后在 Oracle 查询中使用这两个参数)

现在的问题是,当我尝试用空格传递第一个参数时,上面的代码失败了。

例如:/TOM/Process Folders/System Drive/a.jpg

上述给定位置应被视为第一个字符串。如果我在双引号内给出上述内容,那么它可以正常工作。但是我得到的上述参数没有引号。

#!/bin/bash
input=$1

input1=$2

IFS='#' read -a arr <<< "${input//#@#/#}"

for((i=0;i<${#arr[@]};i++))
do
        echo "String$i ${arr[i]}"
done

read passportphotos <<< "${arr[0]}"
read academiccertificates <<< "${arr[1]}"
read dateofbirth <<< "${arr[2]}"
read addressproof <<< "${arr[3]}"
read pancard <<< "${arr[4]}"
read pfnominationform <<< "${arr[5]}"
read gratuitynomination <<< "${arr[6]}"
read investmentdeclaration <<< "${arr[7]}"
read resignationletter <<< "${arr[8]}"
read acceptanceoffer <<< "${arr[9]}"
read acceptancecodeofconduct <<< "${arr[10]}"
read medicalnomination <<< "${arr[11]}"
read backgroungverification <<< "${arr[12]}"
read personaldataform <<< "${arr[13]}"

echo $passportphotos
echo $academiccertificates
echo $dateofbirth
echo $addressproof
echo $pancard
echo $pfnominationform
echo $gratuitynomination
echo $investmentdeclaration
echo $resignationletter
echo $acceptanceoffer
echo $acceptancecodeofconduct
echo $medicalnomination
echo $backgroungverification
echo $personaldataform

instant_client="/root/ora_client/instantclient_11_2"
view=`$instant_client/sqlplus -s HRUSER/HRUSER@TOMLWF <<EOF

set heading off

set feedback off

set lines 10000

set pagesize 10000


insert into EMPLOYEEDOCUMENTS VALUES ((SELECT EMPLOYEEID FROM EMPLOYEE WHERE CANDIDATEID='$input1'),'Resume','Doc','$passportphotos','Y','HR',(SELECT SYSDATE FROM DUAL),'HR',(SELECT SYSDATE FROM DUAL),'HR',(SELECT SYSDATE FROM DUAL));
`

echo $view
4

2 回答 2

2

以这种方式调用您的脚本:

delimiter_new.sh 'company_home/TOM/Proc_joingchecklist_test/Process Instance Documents/Instance.jpg' 14492

您需要在文件名周围加上引号,以便将其视为单个参数。

此外,您不需要sh明确指定,#!/bin/bash脚本中的行告诉操作系统运行 bash。

于 2012-12-14T19:17:46.933 回答
1

我想您实际上不必发布所有代码来说明您在参数中遇到空格问题。

作为补充,在任何编程语言中,使用数组或将值映射到容器(在 bash 的情况下使用关联数组)比创建数十个变量更有用。

编辑

对不起; 正如 Barmar 所指出的,我误读了这篇文章,并且我提出了一些确实改变了你的程序的执行的东西。事实是,如果问题出在命令行参数上,那么您必须将双引号括起来;这就是阅读论点的方式。

但是,您可以将所有参数读入一个数组,然后IFS像您所做的那样更改 。请注意,您的论点必须用手头已知的东西分隔开来,以及在使用IFS='#'.

于 2012-12-14T18:53:23.320 回答