shell腳本用法
⑴ 如何用xshell編寫腳本
1、在編寫shell腳本的時候一般會先查詢伺服器可以使用哪種腳本,並且查看伺服器使用的默認腳本方式是哪一種。
⑵ 如何在shell腳本中使用變數
1、linux shell中的變數一般定義格式為:var=value。其中var是變數名稱,=是賦值,value是給變數賦的值。比如下面的變數定義。
a=12;
b="helloworld"
2、注意變數名稱的第一個字元不可以是數字,但是可以是下劃線。如下示例則為非法的變數名。
3、要使用變數的值,在變數前面加上$符號即可。比如下面的示例:
123=123//這是錯誤的變數名稱
_123=123//這是合法的。
⑶ Shell腳本:${...}在字元串中的多種用法
1、${var}
限定變數。
如果一個變數名A是另一個變數名AB的前部分,那麼,如果要在AB相連時,要得到A的值,就必須使用${var}限定。
如果變數名不會產生歧義時(即獨立的變數名),${var}與$var沒有任何區別。
var="hello"
var_01="hello01"
echo $var $var_01 ${var}_01
>>> hello hello01 hello_01
2、${#var}
得到變數var的長度
var="hello"
echo ${#var}
>>> 5
3、${var#}
刪除變數首部的字元(串),
"#"後面的可以是字面串,也可以是正則表達式(惰性匹配)。
var="hello"
echo ${var#he}
>>> llo
var="/res_pos/path/from/something"
echo ${var#/}
>>> res_pos/path/from/something # 刪除第一個"/"
echo ${var#/*/}
>>> path/from/something # 刪除首部匹配"/*/"的串,即"/res_pos/"
4、${var##}
刪除變數首部的字元(串),
只是,當使用2個"##"時,匹配是貪婪的(貪婪匹配,也就是盡可能多的匹配)。
echo ${var##/*/}
>>> something # 刪除首部匹配"/*/"的串,即"/res_pos/path/from/"。
5、${var%}
刪除變數尾部的字元(串),
"%"後面的可以是字面串,也可以是正則表達式(惰性匹配)。
var="hello"
echo ${var%llo}
>>> he
var="~/res_pos/path/from/something"
echo ${var%/*}
>>> ~/res_pos/path/from # 刪除尾部的"/something"
6、${var%%}
刪除變數尾部的字元(串),
只是,當使用2個"%%"時,匹配是貪婪的(對應於第4條)
var="~/res_pos/path/from/something"
echo ${var%/*}
>>> ~ # 刪除第一個的"/"後的所有所有內容(包括"/"),貪婪匹配中,"/*"就是"/"後的所有字元串
7、${var::}
跟python的切片概念相似,取變數var的起始索引,
指定長度的子串(${var:索引:長度})。
var="~/res_pos/path/from/something"
echo ${var:0:5}
>>> ~/res
echo ${var:1:5}
>>> /res_ # 可見,字元串的索引是從0開始的
echo ${var::5}
>>> ~/res # 省略"索引",默認為從0開始
echo ${var:1:}
>>> # 省略"長度",默認長度為0,所以輸出為空
8、${var//}
字元串替換。
將var中的字元串A替換成字元串B(${var/A/B})。
var="hello world"
echo ${var/hello/hi}
>>> hi world # 字元串"hello"替換成了"hi"
echo ${var/l/X}
>>> heXlo world # 第一個"l"替換成了"X"
9、${var///}
字元串替換,
與第8點相同,只不過,現在是將所有出現的串A替換成串B(${var//A/B})。
var="hello world"
echo ${var//l/X}
>>> heXXo worXd # 所有的"l"都替換成了"X"
10、${var/#/}
替換字元串首部的串A為串B,
(${var/#A/B}),與第8點不同的是,這里只替換首部的串A。
var="hello world. hello baby."
echo ${var//h/H}
>>> Hello world. Hello baby. # 將所有"h"替換成了"H"
echo ${var/#h/H}
>>> Hello world. hello baby. # 將首部的"h"替換成了"H"
echo ${var/e/E}
>>> hEllo world. hello baby. # 將第一個出現的"e"替換成了"E"
echo ${var/#e/E}
>>> hello world. hello baby. # 首字元不是"e",所以沒有進行任何替換,原樣輸出。
11、${var/%/}
替換字元串尾部的串A為串B,
(${var/%A/B}),與第10點相似,只是這是處理的是字元串尾。
var="hello hello"
echo ${var/%o/END}
>>> hello hellEND # 將尾部的字元"o",替換成了"END"。
⑷ shell腳本read命令的用法
read命令是讀取用戶在鍵盤上輸入的信息,然後賦值到一個變數中;read命令是最常用的一個命令,它主要有三個參數,我們一個一個的講解;
最基本用法:
echo-n "輸入你的姓名:"
read name
echo "你的姓名$name"
echo後面的-n是指不換行,應為echo默認是換行的;
--------------------------------------------------------------------------
read -p用法
它的作用是在使用read的命令行是可以直接指定一個提示,例如
read -p "輸入你的姓名" name
也就是把echo省略掉了;
-----------------------------------------------------------------------------
read -t用法
使用read命令後,如果你不在鍵盤上輸入一個信息,那系統會一直等待著你的輸入,而-t的用法就相當於計時器的作用,幾秒中內要是沒有輸入信息,那read命令便不會再等下去;
read -t 5 -p "在五秒內輸入你的姓名" name
-----------------------------------------------------------------------------
read -s用法
隱藏輸入的值,就是在鍵盤上輸入密碼這一類的保密數據時不實時的顯示出來;
⑸ shell腳本中數組的基本用法
首先要告訴大家,Bash Shell 只支持一維數組,而且初始化的時候不用定義數組的大小。
(一) 定義數組,方法1:使用小括弧賦值
array1=(A B C D)或者array1=("A" "B" "C" "D")
定義數組,方法2:使用數組下表挨個賦值
array2[0]=a
array2[1]=b
可能會有朋友會問問什麼不用declare聲明也能用,在這跟大家拓展下,所有變數不用顯式定義都能用作數組,所以用不用declare聲明都可以
(二) 讀取數組
${array[下標值]},例如:${array1[2]}
若要獲取數組中全部的值,使用${array[*]}或者${array[@]}
(三) 獲取數組長度 ${#array1[*]},關鍵在加了個#
(四) 刪除數組內容元素 unset ${array1[下標]} ,刪除整個數組 unset array1
⑹ shell腳本
Shell腳本基本知識
概述:shell其實是內核與用戶之間的一個介面,
shell腳本
如果有一系列經常使用的linux命令,你可以把它們存儲在一個文件腫。shenll可以讀取這個文件,並執行其中的命令。這樣的文件成為腳本文件。
執行shell腳本
要創建一個shell腳本,你要使用任何編輯器比如vi在文本文件中編寫他。
為了使用bashshell賴執行腳本magic,其命令是:bashmagic或者./magic
echo命令:
echo「!」
屏幕上就會回顯「!」
#符號
用於在shell腳本腫可以包含註解入口
echo「hello」
#thisisacommentline.thiswouldnotproceanyoutput!
echo「world!」
第二行是一個註解的例子。它將被shell忽略,而且不產生任何消息
變數:
可以在任何時間通過簡單的賦值來創建。
語法:
<variablename>-<value>
Linux中的所有變數都被當作字元串
引用變數:
$符號用於引用一個變數的內容
variable1=${variable2}
讀入值給變數
在執行shell腳本時,shell還允許用戶直接從鍵盤讀入一個值給變數,還可以使用read命令來作。
$readfname
本地和全局shell變數
局部變數
當引用shell時,只有創建它的shell能夠知道變數的存在
全局變數
稱為子shell
shell中創建的變數局部於創建它的shell,除非使用export命令特別指出是全局的。
環境變數:
通過改變這些變數的值,用戶能夠定製此環境
一些環境變數的例子是HOME,PATH,PS1,PS2,LOGNAME,SHLVL,及SHELL
HOME變數
Linux系統中的每個用戶都有一個相關的稱作HOME的目錄
當一個用戶登錄後,進入相應的HOME的目錄
$echo$HOME
PATH變數
包含一列用冒號定界的目錄的路徑名字,便於可執行程序的搜索。
PS1變數
PS1(PromptString1)變數包含了shell提示符,$符號
$PS1=「HELLO>」
HELLO>
PS2變數
是為第二個提示符設置值的環境變數
LOGNAME變數
包含用戶的注冊名字
$echo「${LOGNAME}」
SHLVL變數
該變數包含當前工作的shelllevel
SHELL變數
環境變數存儲了用戶預設的shell
env命令
可用來查看所有的已移出的環境變數表和它們各自的值!
命令替換
在單個命令行中使用多個命令的另外一種方法(非Pipes)是通過命令替換
echo「thedatais`date`」
expr命令
用於求之算術表達式。該命令的輸出被送到標准輸出
$expr4+5
將在屏幕上顯示9
算術展開:
你可以在$((…))中括一個表達式,用下面的命令來計算它的值;
$((expression))
example1
編寫一個shell腳本用於計算呼叫中心未應答的詢問的數量。該腳本應該接受一天那所報告的詢問的總數和應答的詢問的數量,以便計算未應答的詢問的數量。
所有未應答的詢問總數=所有詢問的總數-應答的詢問的數量
<!--[if!supportLists]-->※<!--[endif]-->※※※※※※※※※※※※※※※※※※※※※※※
條件執行
test和[]
求值表達式,並返回true(0)或false()
數值測試:
-eq等於則為真
-ne不等於則為真
-gt大於則為真
-ge大於等於則為真
-lt小於則為真
-le小於等於則為真
if構造
Linuxshell提供了循環和判定的構造,可以在shell腳本中使用
算術測試
結合if構造,它可以用於測試變數的數字值
串測試
test命令也可以用於字元串
=等於則為真
!=不相等則為真
-z字元串長度為零則為真
-n字元串長度不為零則為真
文件測試
test命令也可以用於檢查文件的狀態
-e文件存在則為真
-r文件存在並且可讀則為真
-w文件存在並且可寫則為真
-x文件存在並且可執行則為真
-s文件存在並且至少有一個字元則為真
-d文件存在並且為目錄則為真
-f文件存在並且為普通文件則為真
-c文件存在並且為字元型文件則為真
-b文件存在並且為塊特殊文件則為真
-a並且-o或者!非
exit命令
用於終止shell腳本的執行並返回到$提示符下
case。。。esac
shell腳本中使用的這個構造依據變數的值而執行一組特定指令
當變數的值和其中的一個值匹配的時候,就執行寫在該值下的一組命令。
example3
迭代
while構造
while<條件>
do
<命令(s)>
done
只有條件為真的時候,才能執行do與done之間的命令
until構造
until循環構造的求值模式於while循環相反
until循環將繼續執行直到求值的條件為真的時候
for構造
forvariable_namein<list_of_values>
do
…
done
for循環取一列值作為輸入並對循環中每個值執行循環
break和contineu命令
同其他語言中的用法
example4
控制進程的執行
請求後台處理
用於請求後台進程的符號是(&)
$wctempfile&
[1]2082
$vinewfile
檢查後台進程
ps(進程狀態)命令為每個當前的活動的每個進程產生一行入口。
終止後台進程
可用kill,如下所示
kill278
查看完成一個命令所花的時間
你可以使用time命令來查看一個命令從開始到結束所花的時間
timefine/etc–name「passwd」2>/dev/null/dev/null表明忽略錯誤信息。
管道的介紹
垂直條(|)是管道字元
它只是shell:「|」前面命令的輸出作為「|」之後命令的輸入發送
ls–l|more
用管道組合命令,功能強大