shell腳本中執行時提示“沒有那個文件或目錄”的解決辦法

故障現象:在終端直接cd /var正常,在shell腳本中執行則報錯。原因是腳本是在windows平臺下寫的,換行符與linux不同,造成腳本不能正確執行

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章