作者:zjruan 日期:2017-06-24
關(guān)鍵詞:shell、終端、syntax error
描述:shell 腳本 異常問(wèn)題記錄
今天在測(cè)試 shell 腳本文件引入的功能,即 Shell 文件包含
. filename #注意(.)號(hào)與filename中間有空格
或
source filename
很簡(jiǎn)單的一條命令,但是執(zhí)行卻一直報(bào)錯(cuò)。于是寫(xiě)了幾個(gè)demo來(lái)測(cè)試一下這個(gè)問(wèn)題。環(huán)境是 Mac 下的終端。

問(wèn)題描述:
源碼如上圖,預(yù)期結(jié)果是
>sh index.sh
name.sh 文件存在
Hello zjruan
但是在執(zhí)行index2.sh的時(shí)候,卻報(bào)錯(cuò)了
>sh index2.sh
index2.sh: line 7: syntax error: unexpected end of file
也有可能是這樣的錯(cuò)誤
>sh index2.sh
'index2.sh: line 6: syntax error near unexpected token `
'index2.sh: line 6: `fi
問(wèn)題分析:
一開(kāi)始以為是代碼的問(wèn)題,于是將實(shí)例代碼完全copy 下來(lái),執(zhí)行,但是依然報(bào)錯(cuò),而且錯(cuò)誤提示基本一致,于是排除手誤寫(xiě)錯(cuò)代碼的可能性,但是它報(bào)的是語(yǔ)法錯(cuò)誤,所以先嘗試這簡(jiǎn)化代碼看看。
第一次嘗試
我們將 index2.sh 精簡(jiǎn)到最簡(jiǎn)單,只有1條命令,
# index2.sh
pwd #打印當(dāng)前位置
然后執(zhí)行(sh index2.sh),結(jié)果執(zhí)行正常,如下圖

第二次嘗試
第一次嘗試的成功,讓我倍感興奮,以為問(wèn)題就要被解決。我們適當(dāng)?shù)脑黾恿舜a的負(fù)責(zé)度,變成了兩行代碼。
執(zhí)行之后,我們發(fā)現(xiàn)報(bào)了一個(gè)錯(cuò)。這兩行簡(jiǎn)單的代碼,肯定不會(huì)寫(xiě)錯(cuò),那再報(bào)錯(cuò)的,肯定就不是代碼的問(wèn)題,于是我們開(kāi)始查看是不是環(huán)境的問(wèn)題。
# index2.sh
pwd #打印當(dāng)前位置
echo 'Hello'
>sh index2.sh
: command not foundpwd
Hello

第三次嘗試
將錯(cuò)誤提示放到 google 和 百度 里都搜索了一下,關(guān)鍵詞是:
syntax error near unexpected token \fi' my.sh: line 6: `fi'`
最終,在眾多的文章里找到了這篇博客,與我的問(wèn)題比較相似。
test.sh: line 8: syntax error near unexpected token `fi'
他的解決方式是:

于是我按照他的思路。將文件都刪除了,使用我vim 新建了文件,在鍵入代碼,發(fā)現(xiàn)執(zhí)行成功。
但是這樣太麻煩了。
現(xiàn)在寫(xiě) demo 還可以刪,但生產(chǎn)環(huán)境的shell腳本也是隨便刪的么?再說(shuō),再敲一遍敲過(guò)的代碼,也是特別煩人的。
于是就思考,window 的 文件格式 與 linux 有什么區(qū)別?
解決
window 文件與 linux 格式最多的區(qū)別是什么呢?
『換行符』
對(duì)就是它,
window下默認(rèn)換行是 CRLF
linux 下默認(rèn)換行是 LF
于是將文件在 CRLF 與 LF間切換,再執(zhí)行,發(fā)現(xiàn)問(wèn)題復(fù)現(xiàn) 和 解決。