1. 程式人生 > >shell指令碼中執行時提示“沒有那個檔案或目錄”的解決辦法

shell指令碼中執行時提示“沒有那個檔案或目錄”的解決辦法

出現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指令碼的確好用,可唯一難的就是格式要求太高!