日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Shell脚本传递带有空格的参数

發(fā)布時間:2025/4/14 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Shell脚本传递带有空格的参数 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

  在另一博文《Shell腳本實現(xiàn)DB2數(shù)據(jù)庫表導(dǎo)出到文件》中實現(xiàn)了通過腳本實現(xiàn)將DB2數(shù)據(jù)庫導(dǎo)出到文件,需要傳入七個參數(shù),最后一個是一個帶有空格字符串,所以傳入的時候有點問題,會自動識別空格,默認(rèn)會將空格前的當(dāng)作第7個參數(shù),以下是傳入的參數(shù):

MD duanwf 23742 CDR_CALL_YYYYMMDD /home/duanwf/asiainfo/export/T141015001_20141014.avl & fetch first 100000 rows only

  最后的“fetch first 100000 rows only”為第七個參數(shù),但是識別的時候只獲取到fetch,日志如下:

2014-10-15 17:51:59 [Thread-9] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:70 - Run Command: /home/duanwf/workspace/shell2.sh MD duanwf 23742 CDR_CALL_YYYYMMDD /home/duanwf/asiainfo/export/T141015001_20141014.avl & fetch first 100000 rows only 2014-10-15 17:51:59 [Thread-9] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - execute sql ................. 2014-10-15 17:51:59 [Thread-9] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - Begin to export the data: 2014-10-15 17:51:59 [Thread-9] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-17:51:59 ====================connect to MD======================= 2014-10-15 17:51:59 [Thread-9] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-17:51:59 db2 connect to MD user duanwf 2014-10-15 17:52:01 [Thread-9] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-17:52:01 Succeed connect to MD 2014-10-15 17:52:01 [Thread-9] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-17:52:01 export to /home/duanwf/asiainfo/export/T141015001_20141014.avl of del modified by nochardel codepage=1208 COLDEL& select * from CDR_CALL_YYYYMMDD fetch:

  

  那要怎么處理呢?

????之前問了有人說可以用雙引號把他引起來,最后結(jié)果還是一樣,無法拿到,只能獲取到

"fetch

  還是會自動在空格前自動斷開。

?

  可以通過$@命令來處理,即將$7換成echo ${@:7},這樣將自動識別到的第7個開始,全部獲取到作為最后第7個參數(shù),參數(shù)獲取改為:

#!/bin/bashDBSCHEMA=$1 DBUSER=$2 DBPASSWORD=$3 TABLENAME=$4 FILEPATH=$5 DELIMITER=$6 EXPORTLIMIT=`echo ${@:7}`

  再次運行結(jié)果:

2014-10-15 23:36:05 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:57 - Export Parameters: MD duanwf 23742 ST_ZGD_SCOPE_RSFR_GR_DM_201409 /home/duanwf/asiainfo/export/M141015003_201409.avl & fetch first 100000 rows only 2014-10-15 23:36:05 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:70 - Run Command: /home/duanwf/workspace/shell/db2.sh MD duanwf 23742 ST_ZGD_SCOPE_RSFR_GR_DM_201409 /home/duanwf/asiainfo/export/M141015003_201409.avl & fetch first 100000 rows only 2014-10-15 23:36:05 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - execute sql ................. 2014-10-15 23:36:05 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - Begin to export the data: 2014-10-15 23:36:05 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-23:36:05 ====================connect to MD======================= 2014-10-15 23:36:05 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-23:36:05 db2 connect to MD user duanwf 2014-10-15 23:36:08 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-23:36:08 Succeed connect to MD 2014-10-15 23:36:08 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - \n2014/10/15-23:36:08 export to /home/duanwf/asiainfo/export/M141015003_201409.avl of del modified by nochardel codepage=1208 COLDEL& select * from ST_ZGD_SCOPE_RSFR_GR_DM_201409 fetch first 100000 rows only: 2014-10-15 23:36:09 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - SQL3104N EXPORT 實用程序 正在開始將數(shù)據(jù)導(dǎo)出至文件 2014-10-15 23:36:09 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - "/home/duanwf/asiainfo/export/M141015003_201409.avl"2014-10-15 23:36:09 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - 2014-10-15 23:36:09 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - SQL3105N Export 實用程序已經(jīng)完成導(dǎo)出 "12742" 行。 2014-10-15 23:36:09 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - 2014-10-15 23:36:09 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - 2014-10-15 23:36:09 [Thread-2] INFO com.asiainfo.dmp.proc.ExportDataServiceDB2.ExportData:78 - 導(dǎo)出的行數(shù):12742

問題解決!!

?

<--------------------------------- 我是華麗的分割線 --------------------------------->

?

補(bǔ)充對Shell函數(shù)參數(shù)的說明:

來源:http://www.w3cschool.cc/linux/linux-shell-func.html

?

在Shell中,調(diào)用函數(shù)時可以向其傳遞參數(shù)。在函數(shù)體內(nèi)部,通過 $n 的形式來獲取參數(shù)的值,例如,$1表示第一個參數(shù),$2表示第二個參數(shù)...

帶參數(shù)的函數(shù)示例:

#!/bin/bash funWithParam(){echo "The value of the first parameter is $1 !"echo "The value of the second parameter is $2 !"echo "The value of the tenth parameter is $10 !"echo "The value of the tenth parameter is ${10} !"echo "The value of the eleventh parameter is ${11} !"echo "The amount of the parameters is $# !"echo "The string of the parameters is $* !" } funWithParam 1 2 3 4 5 6 7 8 9 34 73

輸出結(jié)果:

The value of the first parameter is 1 ! The value of the second parameter is 2 ! The value of the tenth parameter is 10 ! The value of the tenth parameter is 34 ! The value of the eleventh parameter is 73 ! The amount of the parameters is 12 ! The string of the parameters is 1 2 3 4 5 6 7 8 9 34 73 !"

注意,$10 不能獲取第十個參數(shù),獲取第十個參數(shù)需要${10}。當(dāng)n>=10時,需要使用${n}來獲取參數(shù)。

另外,還有幾個特殊字符用來處理參數(shù):

參數(shù)處理說明
$#傳遞到腳本的參數(shù)個數(shù)
$*以一個單字符串顯示所有向腳本傳遞的參數(shù)
$$腳本運行的當(dāng)前進(jìn)程ID號
$!后臺運行的最后一個進(jìn)程的ID號
$@與$#相同,但是使用時加引號,并在引號中返回每個參數(shù)。
$-顯示Shell使用的當(dāng)前選項,與set命令功能相同。
$?顯示最后命令的退出狀態(tài)。0表示沒有錯誤,其他任何值表明有錯誤。

?

轉(zhuǎn)載于:https://www.cnblogs.com/dwf07223/p/4027742.html

總結(jié)

以上是生活随笔為你收集整理的Shell脚本传递带有空格的参数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。