出現bad interpreter:No such file or directory的原因,是檔案格式的問題。這個檔案是在Windows下編寫的。換行的方式與Unix不一樣,但是在vim下面如果不Set一下又完全看不出來。
問題分析:
1、將windows 下編寫好的SHELL檔案,傳到linux下執行,提示出錯。
2、出錯資訊:bad interpreter: 沒有那個檔案或目錄。
問題原因:
因為作業系統是windows,在windows下編輯的指令碼,所以有可能有不可見字元。指令檔是DOS格式的
即每一行的行尾以\r\n來標識, 其ASCII碼分別是0x0D, 0x0A.
解決方案:
可以有很多種辦法看這個檔案是DOS格式的還是UNIX格式的, 還是MAC格式的
(1) vim filename
然後用命令 :set ff
可看到dos或unix的字樣,如果的確是dos格式的, 那麼用set ff=unix把它強製為unix格式的,,然後存檔退出後就可運行。
轉換不同平台的文字檔格式可以用
1. unix2dos或dos2unix這兩個小程式來做. 很簡單. 在djgpp中這兩個程式的名字叫dtou和utod, u代表unix, d代表dos
2. 也可以用sed 這樣的工具來做:
複製代碼 代碼如下:
sed ‘s/^M//' filename > tmp_filename
mv -f tmp_filename filename
特別說明:^M並不是按鍵shift + 6產生的^和字母M, 它是一個字元, 其ASCII是0x0D, 產生它的辦法是先按CTRL+V, 然後再斷行符號(或CTRL+M)
另外, 當SHELL程式報告command not found時, 總是去檢查一下你的PATH裡面有沒有程式要用到的每一個命令(沒指定絕對路徑的那種). 你這麼小的程式, 可以一行一行核對。
附:少寫一個/引發的沒有那個檔案或目錄問題
今天在翻看以前寫的簡單的shell指令碼時,發現一個問題:
當./運行時總是提示: (bash: ./hello.sh: bin/bash: 壞的解譯器: 沒有那個檔案或目錄),但是當用sh運行時正確.
原來的指令碼:
(試試看你能否一眼看出錯誤)
複製代碼 代碼如下:
#!bin/bash
echo "Hello Linux!"
後來幾番檢查發現自己寫的丟了一些東西.
應該把第一行改成 #!/bin/bash ,少寫了一個/
唉,很簡單的問題,自己以前沒有發現還有這樣的錯誤! shell指令碼的確好用,可唯一難的就是格式要求太高!