腳本shebang的作用與使用方法

#!(稱為 shebanghashbang)是腳本文件開頭的前兩個字符,用于告訴操作系統應該使用哪個解釋器來執行該腳本。

核心作用:

  1. 指定解釋器: 明確告訴系統運行這個腳本時應該調用哪個程序(解釋器)來解析腳本內容。
  2. 使腳本可像程序一樣直接執行: 當你在終端中輸入腳本文件名(如 ./myscript.sh)并按下回車時,操作系統會讀取 shebang 行,找到指定的解釋器,然后將腳本文件作為參數傳遞給該解釋器執行。你不再需要手動輸入 python myscript.pybash myscript.sh

基本語法:

#!interpreter_path [optional_argument]
  • #!:固定的開頭符號。
  • interpreter_path解釋器的絕對路徑。這是最關鍵的部分。
  • [optional_argument]:可選的傳遞給解釋器的單個參數(較少用)。

使用方法:

  1. 必須是文件的第一行: Shebang 必須位于腳本文件的第一行,并且是文件的最開頭兩個字符。
  2. 使用絕對路徑: 解釋器的路徑必須是絕對路徑(從根目錄 / 開始的完整路徑)。系統不會像在終端中那樣自動搜索 PATH 環境變量來查找解釋器。
  3. 賦予腳本執行權限: 在添加 shebang 后,你需要使用 chmod 命令給腳本文件添加可執行權限,才能像程序一樣直接運行它:
    chmod +x your_script_name
    

常見寫法示例:

  1. Bash Shell 腳本:

    #!/bin/bash
    echo "Hello from Bash!"
    

    保存為 hello.sh,然后 chmod +x hello.sh,最后運行 ./hello.sh

  2. Python 腳本:

    #!/usr/bin/python3
    print("Hello from Python 3!")
    

    保存為 hello.py,然后 chmod +x hello.py,最后運行 ./hello.py

  3. 使用 /usr/bin/env 查找解釋器(推薦寫法):

    #!/usr/bin/env bash
    # 或者用于 Python
    #!/usr/bin/env python3
    
    • 優點: 更靈活、更具可移植性。/usr/bin/env 命令會在當前用戶的 PATH 環境變量中查找指定的解釋器(如 bash, python3, node, perl 等)。這樣你就不需要硬編碼解釋器的絕對路徑(不同系統或用戶安裝路徑可能不同),只要該解釋器在 PATH 中就能找到。
    • 推薦: 這是現代腳本編寫中更推薦的方式,尤其是當你希望腳本能在不同環境(不同用戶、不同系統)中運行時。
  4. 帶參數的解釋器(較少用):

    #!/bin/bash -e  # 告訴 bash 如果任何命令失敗(返回非零狀態)就立即退出腳本
    #!/usr/bin/perl -w  # 打開 perl 的警告
    

總結使用步驟:

  1. 創建你的腳本文件(如 myscript.sh)。
  2. 在文件的第一行寫入 shebang,指定正確的解釋器路徑(推薦用 #!/usr/bin/env interpreter_name)。
  3. 保存文件。
  4. 在終端中,切換到腳本所在目錄,運行 chmod +x myscript.sh 賦予執行權限。
  5. 通過輸入腳本的路徑來執行它:
    • 如果腳本在當前目錄:./myscript.sh
    • 如果腳本在 PATH 包含的目錄中:myscript.sh (需要先 chmod +x 和確保目錄在 PATH 中)

重要注意事項:

  • 僅對腳本文件有效: Shebang 只對可執行的腳本文件有意義。對于需要顯式傳遞給解釋器的文件(如 bash script.shpython script.py),shebang 行會被當作普通注釋處理。
  • 文件編碼: 腳本文件通常應該保存為純文本格式,并且沒有字節順序標記(BOM),尤其是在 Unix/Linux 系統上。建議使用 UTF-8 無 BOM 編碼。
  • Windows: Shebang 在原生 Windows 命令提示符(cmd.exe)或 PowerShell 中不被識別。在這些環境中,文件擴展名(如 .py, .pl, .rb)通常關聯到對應的解釋器。但在 Windows Subsystem for Linux (WSL) 或 Git Bash/Cygwin 等類 Unix 環境中,shebang 是有效的。
  • 錯誤路徑: 如果 shebang 中指定的解釋器路徑不存在或不可執行,當你嘗試直接運行腳本時會收到類似 "bad interpreter: No such file or directory" 的錯誤。

總而言之,shebang 是讓腳本文件能夠自包含其解釋器需求并像獨立程序一樣直接執行的關鍵機制。 使用 #!/usr/bin/env interpreter 是最通用和推薦的做法。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/86667.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/86667.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/86667.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【大模型學習 | BERT 量化學習 (1)】

BERT 情感分析 一、 數據集加載與模型訓練 from transformers import BertTokenizer, BertForSequenceClassification, Trainer, TrainingArguments from datasets import load_dataset import torch import numpy as np from sklearn.metrics import accuracy_score mode_na…

用低通濾波優化串口或485 通信指示燈電路

常見的通信指示燈電路就是簡單的把LED 連到TXD 和RXD 上,一有動靜就閃一下。問題是,如果波特率很高,一次通信時間很短,相當于占空比很低,LED 閃爍的亮度就很弱,不容易觀察。比如MODBUS 通信,波特…

【純干貨】調整word目錄中的行距以及右對齊頁碼

1.問題展現 目錄生成會遇到一些奇葩現象 所以到了展現技術力的時候了【doge】 2.解決word目錄中的行距問題 選中目錄中的文字-》段落 此時你可能勾選了圖片中的一個以上,把他們都取消了, 由于一個目錄的標題對應一個樣式,第一個也可以取消 …

pandas 優雅處理值類型為list的列的csv讀寫問題

文章目錄 直接存儲join list 變成字符串存儲json.dumps序列化存儲以及json.loads反序列化讀取總結 之所以分析這個問題,是因為讀者在跟第三方數據供應商對接數據的時候,老是會遇到數據加載都會出錯的問題,其中一個原因就是list類型數據沒有正確儲存,于是筆者在這篇文章里面詳細…

一種解決 OpenWrt 安裝 docker 之后局域網的設備之間無法互相訪問通信的方法

文章目錄 一、問題背景二、解決方案(方法一)修改全局設置的 轉發( forward) 為 接受(ACCEPT)(方法二)設置 net.bridge.bridge-nf-call-iptables0 并將 docker 的容器網絡設置為host …

Leetcode百題斬-貪心

貪心也是一個很有意思的專題,能遇到很多神奇的思路。 但這個專題,leetcode也沒放Hard,果然是怕這種玄學專題上點難度大家罩不住。那就很快了,直接過 763. Partition Labels[Medium] 思路:將字母串分組,相…

基于多徑信道的分集接收技術性能優化與仿真分析

基于多徑信道的分集接收技術性能優化與仿真分析 一、多徑信道建模與仿真 1. 多徑信道建模(MATLAB實現) classdef MultipathChannel < handlepropertiesSampleRate = 1e6; % 采樣率 (Hz)MaxDoppler = 100; % 最大多普勒頻移 (Hz)DelayVector = [0

LeetCode 713.乘積小于K的子數組

給你一個整數數組 nums 和一個整數 k &#xff0c;請你返回子數組內所有元素的乘積嚴格小于 k 的連續子數組的數目。 示例 1&#xff1a; 輸入&#xff1a;nums [10,5,2,6], k 100 輸出&#xff1a;8 解釋&#xff1a;8 個乘積小于 100 的子數組分別為&#xff1a;[10]、[5…

打破網絡安全孤島:實現防御數據協作

作者&#xff1a;來自 Elastic Crossley McEwen, Oksana Abramovych 現代網絡戰場不再受組織邊界的限制。在各類防御網絡中&#xff0c;關鍵的結構化、非結構化和半結構化數據分布在不同的專業環境中&#xff0c;形成孤島 —— 從機密情報系統到作戰指揮平臺&#xff0c;再到戰…

給定一個沒有重復元素的數組,寫出生成這個數組的MaxTree的函數

題目&#xff1a; 給定一個沒有重復元素的數組arr&#xff0c;寫出生成這個數組的MaxTree的 函數&#xff0c;要求如果數組長度為N&#xff0c;則時間復雜度為O(N)、額外空間復雜度 為O(N)。 一個數組的MaxTree定義如下。 ● 數組必須沒有重復元素。 ● MaxTree是一棵二叉…

iOS 抓包實戰:時間戳偏差導致的數據同步異常排查記錄

“這條數據不是我填的”“我的更新被覆蓋了”“兩個設備顯示不一致”——這些是產品上線后最令人頭疼的反饋。 最近我們在一次用戶同步問題排查中&#xff0c;發現表面是“數據丟失”問題&#xff0c;實則是多端數據提交時間戳處理不一致&#xff0c;導致后臺認為老數據為新&a…

一款支持多日志器、多級別、多落地方式的同異步日志系統

文章目錄 簡介項目特點項目實現基礎功能模塊實現文件操作以及日期時間獲取日志等級日志信息描述 異步功能模塊實現緩沖區實現異步線程實現 核心功能模塊實現日志格式解析落地操作實現日志器實現 測試測試環境測試參數測試結果性能分析 附件 簡介 在現代軟件開發與系統運維領域…

加固筆記本在戶外勘探行業的應用:探索與科技的融合

在自然資源勘探、地質調查、石油天然氣開發、礦產資源測繪等戶外勘探行業中&#xff0c;作業環境常常復雜多變&#xff1a;風沙漫天的戈壁、雨雪交加的山區、濕熱潮濕的叢林&#xff0c;甚至是極寒與高溫并存的極端氣候條件。面對這些挑戰&#xff0c;普通的辦公設備早已無法勝…

MySQL 連接指定端口后,為什么實際仍是 3306?

文章目錄 MySQL 連接指定端口后&#xff0c;為什么實際仍是 3306&#xff1f;問題現象復現原因分析沒有指定 -h&#xff0c;默認走的是本地 Unix Socket多實例環境中未顯式指定目標地址 正確的連接方法方法一&#xff1a;添加 -h 127.0.0.1方法二&#xff1a;添加 --protocolTC…

【Android當用戶兩次打斷息屏操作后,屏幕將會在10分鐘內無法熄滅并持續點亮(關閉Android13新增的dim功能)】

UndimDetectorWakeLock持鎖導致屏幕不滅問題處理SOP 問題描述 在Android T版本中&#xff0c;系統新增了SCREEN_BRIGHT_WAKE_LOCK&#xff08;UndimDetectorWakeLock&#xff09;機制。當設備處于低亮度&#xff08;dim&#xff09;狀態時&#xff0c;用戶兩次打斷屏幕熄滅操…

Tailwind CSS自定義用法

文章目錄 前言? 一、集成 Tailwind CSS 到 React 項目1. 安裝依賴2. 配置 tailwind.config.js3. 創建全局樣式文件&#xff08;如 src/index.css&#xff09;tailwind base;tailwind components;tailwind utilities; 4. 在 main.tsx 或 main.jsx 中引入樣式 ? 二、自定義樣式…

linux面試常考

常用指令 常見題

Spring Boot 2.2.6調用DeepSeek API并通過SSE將流式響應推送給前端的完整實現

1. 添加依賴 (pom.xml) <dependencies><!-- Spring Boot Web --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- SSE 支持 --><depe…

LM1117-ADJ 簡單介紹

LM1117-ADJ是一款可調輸出電壓的低壓差線性穩壓器&#xff08;LDO&#xff09;&#xff0c;具有以下關鍵特性和應用要點&#xff1a; 核心特性 可調輸出電壓 通過外部分壓電阻&#xff08;R1和R2&#xff09;調節輸出電壓&#xff0c;范圍為1.25V至13.8V。輸出電壓公式&#…

知名流體控制解決方案供應商“永盛科技”與商派ShopeX達成B2B商城項目合作

2025年6月&#xff0c;全球知名的工業流體控制解決方案服務商——永盛科技&#xff08;股票&#xff1a;874497&#xff09;&#xff0c;與商派ShopeX正式達成B2B商城項目合作。 此次合作將共同推動永盛科技B2B業務的數字化變革&#xff0c;提高B2B業務運營效率&#xff0c;同…