查看“Shell”的源代码
←
Shell
跳到导航
跳到搜索
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
=== 简介 === ==== 什么是 shell ==== * Shell 是一个用 C 语言编写的程序,它是用户使用 Linux 的桥梁。 * Shell 既是一种命令语言,又是一种程序设计语言。 * Shell 是指一种应用程序,这个应用程序提供了一个界面,用户通过这个界面访问 Linux 内核的服务。 ==== 什么是 shell 脚本 ==== Shell 脚本(shell script),是一种为 shell 编写的脚本程序,一般文件后缀为 <code>.sh</code>。 ==== shell 环境 ==== ==== 模式 ==== ===== 交互模式 ===== ===== 非交互模式 ===== === 基本语法 === ==== 解释器 ==== ==== 注释 ==== ==== echo ==== echo 用于字符串的输出。 * 输出普通字符串:<syntaxhighlight lang="shell"> echo "hello, world" # Output: hello, world </syntaxhighlight> * 输出含变量的字符串:<syntaxhighlight lang="shell"> name=xiaoming echo "hello, \"${name}\"" # Output: hello, "xiaoming" </syntaxhighlight> * 输出含换行符的字符串:<syntaxhighlight lang="shell"> # 输出含换行符的字符串 echo "YES\nNO" # Output: YES\nNO echo -e "YES\nNO" # -e 开启转义 # Output: # YES # NO </syntaxhighlight> * 输出含不换行符的字符串:<syntaxhighlight lang="shell"> echo "YES" echo "NO" # Output: # YES # NO echo -e "YES\c" # -e 开启转义 \c 不换行 echo "NO" # Output: # YESNO </syntaxhighlight> * 输出重定向至文件:<syntaxhighlight lang="shell"> echo "test" > test.txt </syntaxhighlight> * 输出执行结果:<syntaxhighlight lang="shell"> echo `pwd` # Output:(当前目录路径) </syntaxhighlight> ==== printf ==== printf 用于格式化输出字符串。 printf 命令的语法: printf format-string [arguments...] 参数说明: * '''format-string:''' 为格式控制字符串 * '''arguments:''' 为参数列表。 默认,printf 不会像 echo 一样自动添加换行符,如果需要换行可以手动添加 <code>\n</code>。 === 变量 === 跟许多程序设计语言一样,你可以在 bash 中创建变量。 bash 中没有数据类型,bash 中的变量可以保存一个数字、一个字符、一个字符串等等。同时无需提前声明变量,给变量赋值会直接创建变量。 ==== 变量命名原则 ==== * 命名只能使用英文字母,数字和下划线,首个字符不能以数字开头。 * 中间不能有空格,可以使用下划线(_)。 * 不能使用标点符号。 * 不能使用 bash 里的关键字(可用 help 命令查看保留关键字)。 ==== 声明变量 ==== 访问变量的语法形式为:<code>${var}</code> 和 <code>$var</code> 。 变量名外面的花括号是可选的,加不加都行,加花括号是为了帮助解释器识别变量的边界,所以推荐加花括号。<syntaxhighlight lang="shell"> word="hello" echo ${word} # Output: hello </syntaxhighlight> ==== 只读变量 ==== 使用 readonly 命令可以将变量定义为只读变量,只读变量的值不能被改变。<syntaxhighlight lang="shell"> rword="hello" echo ${rword} readonly rword # rword="bye" # 如果放开注释,执行时会报错 </syntaxhighlight> ==== 删除变量 ==== 使用 unset 命令可以删除变量。变量被删除后不能再次使用。unset 命令不能删除只读变量。<syntaxhighlight lang="shell"> dword="hello" # 声明变量 echo ${dword} # 输出变量值 # Output: hello unset dword # 删除变量 echo ${dword} # Output: (空) </syntaxhighlight> ==== 变量类型 ==== * '''局部变量''' :局部变量是仅在某个脚本内部有效的变量。它们不能被其他的程序和脚本访问。 * '''环境变量''' :环境变量是对当前 shell 会话内所有的程序或脚本都可见的变量。创建它们跟创建局部变量类似,但使用的是 <code>export</code> 关键字,shell 脚本也可以定义环境变量。 常见的环境变量: {| class="wikitable" !变量 !描述 |- |<code>$HOME</code> |当前用户的用户目录 |- |<code>$PATH</code> |用分号分隔的目录列表,shell 会到这些目录中查找命令 |- |<code>$PWD</code> |当前工作目录 |- |<code>$RANDOM</code> |0 到 32767 之间的整数 |- |<code>$UID</code> |数值类型,当前用户的用户 ID |- |<code>$PS1</code> |主要系统输入提示符 |- |<code>$PS2</code> |次要系统输入提示符 |} === 字符串 === ==== 单引号和双引号 ==== shell 字符串可以用单引号 <code><nowiki>''</nowiki></code>,也可以用双引号 <code>“”</code>,也可以不用引号。 * 单引号的特点 ** 单引号里不识别变量 ** 单引号里不能出现单独的单引号(使用转义符也不行),但可成对出现,作为字符串拼接使用。 * 双引号的特点 ** 双引号里识别变量 ** 双引号里可以出现转义字符 综上,推荐使用双引号。 ==== 拼接字符串 ==== <syntaxhighlight lang="shell"> # 使用单引号拼接 name1='white' str1='hello, '${name1}'' str2='hello, ${name1}' echo ${str1}_${str2} # Output: # hello, white_hello, ${name1} # 使用双引号拼接 name2="black" str3="hello, "${name2}"" str4="hello, ${name2}" echo ${str3}_${str4} # Output: # hello, black_hello, black </syntaxhighlight> ==== 获取字符串长度 ==== <syntaxhighlight lang="shell"> text="12345" echo ${#text} # Output: # 5 </syntaxhighlight> ==== 截取子字符串 ==== <syntaxhighlight lang="shell"> text="12345" echo ${text:2:2} # Output: # 34 </syntaxhighlight> ==== 查找子字符串 ==== <syntaxhighlight lang="shell"> text="hello" echo `expr index "${text}" ll` #查找 ll 子字符在 hello 字符串中的起始位置。 # Output: # 3 </syntaxhighlight> === 数组 === bash 只支持一维数组。数组下标从 0 开始,下标可以是整数或算术表达式,其值应大于或等于 0。 ==== 创建数组 ==== <syntaxhighlight lang="shell"> # 创建数组的不同方式 nums=([2]=2 [0]=0 [1]=1) colors=(red yellow "dark blue") </syntaxhighlight> ==== 访问数组元素 ==== * 访问数组的单个元素: <syntaxhighlight lang="shell"> echo ${nums[1]} # Output: 1 </syntaxhighlight> * 访问数组的所有元素: <syntaxhighlight lang="shell"> echo ${colors[*]} # Output: red yellow dark blue echo ${colors[@]} # Output: red yellow dark blue </syntaxhighlight> * 访问数组的部分元素: <syntaxhighlight lang="shell"> echo ${nums[@]:0:2} # Output: # 0 1 </syntaxhighlight>在上面的例子中,<code>${array[@]}</code> 扩展为整个数组,<code>:0:2</code>取出了数组中从 0 开始,长度为 2 的元素。 ==== 访问数组长度 ==== <syntaxhighlight lang="shell"> echo ${#nums[*]} # Output: # 3 </syntaxhighlight> ==== 向数组中添加元素 ==== <syntaxhighlight lang="shell"> colors=(white "${colors[@]}" green black) echo ${colors[@]} # Output: # white red yellow dark blue green black </syntaxhighlight>上面的例子中,<code>${colors[@]}</code> 扩展为整个数组,并被置换到复合赋值语句中,接着,对数组<code>colors</code>的赋值覆盖了它原来的值。 ==== 从数组中删除元素 ==== 用<code>unset</code>命令来从数组中删除一个元素:<syntaxhighlight lang="shell"> unset nums[0] echo ${nums[@]} # Output: # 1 2 </syntaxhighlight> === 运算符 === ==== 算术运算符 ==== 下表列出了常用的算术运算符,假定变量 x 为 10,变量 y 为 20: {| class="wikitable" !运算符 !说明 !举例 |- | + |加法 |<code>expr $x + $y</code> 结果为 30。 |- | - |减法 |<code>expr $x - $y</code> 结果为 -10。 |- |* |乘法 |<code>expr $x * $y</code> 结果为 200。 |- |/ |除法 |<code>expr $y / $x</code> 结果为 2。 |- |% |取余 |<code>expr $y % $x</code> 结果为 0。 |- |= |赋值 |<code>x=$y</code> 将把变量 y 的值赋给 x。 |- |== |相等。用于比较两个数字,相同则返回 true。 |<code>[ $x == $y ]</code> 返回 false。 |- |!= |不相等。用于比较两个数字,不相同则返回 true。 |<code>[ $x != $y ]</code> 返回 true。 |} '''注意:'''条件表达式要放在方括号之间,并且要有空格,例如: <code>[$x==$y]</code> 是错误的,必须写成 <code>[ $x == $y ]</code>。 ==== 关系运算符 ==== 关系运算符只支持数字,不支持字符串,除非字符串的值是数字。 下表列出了常用的关系运算符,假定变量 x 为 10,变量 y 为 20: {| class="wikitable" !运算符 !说明 !举例 |- |<code>-eq</code> |检测两个数是否相等,相等返回 true。 |<code>[ $a -eq $b ]</code>返回 false。 |- |<code>-ne</code> |检测两个数是否相等,不相等返回 true。 |<code>[ $a -ne $b ]</code> 返回 true。 |- |<code>-gt</code> |检测左边的数是否大于右边的,如果是,则返回 true。 |<code>[ $a -gt $b ]</code> 返回 false。 |- |<code>-lt</code> |检测左边的数是否小于右边的,如果是,则返回 true。 |<code>[ $a -lt $b ]</code> 返回 true。 |- |<code>-ge</code> |检测左边的数是否大于等于右边的,如果是,则返回 true。 |<code>[ $a -ge $b ]</code> 返回 false。 |- |<code>-le</code> |检测左边的数是否小于等于右边的,如果是,则返回 true。 |<code>[ $a -le $b ]</code>返回 true。 |} ==== 布尔运算符 ==== ==== 逻辑运算符 ==== ==== 字符串运算符 ==== ==== 文件测试运算符 ==== === 控制语句 === ==== 条件语句 ==== ==== if ==== ==== if else ==== ==== if elif else ==== ==== case ==== === 循环语句 === ==== for循环 ==== ==== while循环 ==== ==== until循环 ==== ==== select循环 ==== ==== break和continue ==== === 函数 === ==== 位置参数 ==== ==== 函数处理参数 ====
返回至“
Shell
”。
导航菜单
个人工具
登录
名字空间
页面
讨论
变体
视图
阅读
查看源代码
查看历史
更多
搜索
导航
-==扬==-
-==帆==-
-==起==-
-==航==-
最近更改
随机页面
MediaWiki帮助
工具
链入页面
相关更改
特殊页面
页面信息