shell学习总结-1

1、查看系统所有shell和默认shell

查看系统所有的shell:

cat /etc/shells

查看系统默认shell:

echo  $SHELL

2、第一个shell脚本,打印字符串Hello World

新建文件1.sh,在1.sh中输入代码:

1 #!/bin/sh
2 echo  "Hello  World"

第一行#!告诉脚本要用什么解释器来执行,/bin/sh是解释器的路径。

第二行echo命令表示向标准输出文件(一般是指显示器)输出文件,""包裹的表示字符串。

3、执行shell脚本

a、

1 #进入脚本所在路径
2 #给脚本赋予可执行权限
3 chmod +x  1.sh
4 #执行脚本
5 ./1.sh

b、

#无需在脚本第一行指定解释器信息1 /bin/sh  1.sh

c、

1 source  1.sh
2 #source可以简写成.
3
4 #source 1.sh等价于
5 . 1.sh
6
7 #执行当前目录下的1.sh
8 . ./1.sh

4、shell变量

在 Bash shell 中,每一个变量的值都是字符串,无论你给变量赋值时有没有使用引号,值都会以字符串的形式存储。

定义变量的三种方式:

1 var_name=value1
2 var_name3=‘value2‘
3 var_name3="value3"
4 #=两边不能有空格

shell变量命名规范:

  • 变量名由数字、字母、下划线组成;
  • 必须以字母或者下划线开头;
  • 不能使用 Shell 里的关键字(通过 help 命令可以查看保留关键字)。

定义变量举例:

1 name="Stephen Wang"
2 job="JAVA  Dev"
3 company="ZTE"
4
5 echo ${name}

单引号和双引号的区别:

使用单引号包裹变量时{}里面的内容会原样输出;双引号包含变量时会先解析变量。例子如下:

1 #!/bin/sh
2 name="Vicent"
3 info=‘My name is ${name}‘
4 echo ${info}#My name is ${name}
5 info="My name is ${name}"
6 echo ${info}#My name is Bob

引用变量:

1 #引用变量在变量名称前面加上$即可
2 ${name}
3 $name
1 变量外面{}是可选的,作用是为了识别边界,应用举例
2 name="Bob"
3 echo  "My name is ${name}what is  your name?"

建议引用变量时都加上{}

修改变量值:

1 name="Bob"
2 echo "my name is ${name}"#修改name的值为Vicent3 name="Vicent"
4 echo "My name is ${name}"

只读变量:

1 name="Bob"
2 echo "my name is ${name}"#定义name为只读变量3 readonly name
4 name="Vicent"
5 echo "My name is ${name}"

删除变量:

1 #删除变量name
2 unset name

将命令的运行结果赋值给变量:

1 #var1=`command1`
2 #var2=$(command1)
3
4 var1=`pwd`
5 echo ${var1}
6 var2=$(date)
7 echo ${var2}

5、shell数组

shell数组定义:

1 array_name=(var1 var2  var3  var4)

获取数组元素,下表从零开始:

1 ${array_name[index]}#@或*表示所有元素

赋值:

1 array_name[index]=value

获取数组的长度:

1 ${#array_name[@]}
2
3 ${#array_name[*]}

删除数组元素:

1 unset  array_name[index]

数组常用语法实例:

 1 #!/bin/sh
 2 arr1=(data1 data2 data3  data4)
 3 #赋值
 4 arr1[4]=data5
 5 #获取第5个元素,下表从0开始
 6 echo ${arr1[4]}  #输出data5
 7 #获取数组长度
 8 echo ${#arr1[@]} #输出5
 9
10 #删除第一个元素
11 unset arr1[0]
12
13 echo ${#arr1[@]} #输出4

原文地址:https://www.cnblogs.com/webDepOfQWS/p/10624648.html

时间: 2024-08-30 15:28:06

shell学习总结-1的相关文章

shell学习之tr命令

tr命令不接受指定的文件参数,而只是对标准输入进行翻译, tr是translate的简写,亦即翻译,需要注意的是,它不能翻译句子,只能翻译单个字符. 首先,定义变量:     [[email protected]]#A=1,,2,,,3,,,4,,,5 下面以示例对该命令以及其常用选项进行介绍. 示例: 1.  无选项设置情况     [[email protected]]# echo $A | tr  ',' ' '         1 2   3   4   5     [[email pr

【转】十分有用的linux shell学习总结

在最近的日常工作中由于经常会和Linux服务器打交道,如Oracle性能优化.我们 数据采集服务器的资源利用率监控,以及Debug服务器代码并解决其效率和稳定性等问题.因此这段时间总结的有关Linux Shell的系列博客就给予了我极大的帮助,然而在实际的使用中却发现,有的时候确实忘记了某个技术点或某个Shell命令的使用方式曾经在哪一篇博客中 予以了说明,所以不得不多次点击多篇博客,直到找到想要那篇的为止,鉴于此,为了方便我们每个人的查阅,这里特别给出了前十二篇系列博客的目录以供大家参 阅和查

shell学习总结之自定义函数

shell学习总结之自定义函数 Myfun (){ echo patams1 is $1 echo -n "now i is $i " ! [ "$i" ] && exit ; echo jj return '1' } myf=$(Myfun); echo myf Myfun 12 unset Myfun Myfun echo 'the end !'$myf 别人的 #! bin/bash # ----------------------------

第八章 shell学习之循环和结构化命令

for循环 1. 列表for循环 for variable in {list}  #有些像C++/CLR中的for each do ... done 如: 1. [[email protected] tmp]# cat b.sh #! /bin/bash for i in 1 2 3 4 5      #1 2 3 4 5等价于{1..5} do echo $i done [[email protected] tmp]# ./b.sh 1 2 3 4 5 2. [[email protected

Shell学习笔记——第三章

第三章 /etc/passwd 文件包含一个所有系统用户账户组成的列表,以及一些关于每个用户的基本信息. 例rich:x:501:Rich Blum:/home/rich:/bin/bash 每个条目都有7个数据字段,例使用冒号分隔.系统使用这些字段中的数据向用户分配具体的特性.这些字段分别有 用户名:用户密码(如果密码存储在其他文件中,则为占位符):用户的系统用户ID编号:用户的系统组的ID编号:用户的全名:用户默认的主目录:用户的默认Shell目录: cd 命令 略过 列表命令(ls) 参数

Shell学习之:输入输出重定向

详细理解: linux命令默认从标准输入设备(stdin)获取输入,将结果输出到标准输出设备(stdout)显示.一般情况下,标准输入设备就是键盘,标准输出设备就是终端,即显示器.在linux shell执行命令时,每个进程都和三个打开的文件相联系,并使用文件描述符来引用这些文件.由于文件描述符不容易记忆,shell同时也给出了相应的文件名: 文件描述符说明列表 文件 文件描述符 输入文件-标准输入 0(缺省为键盘;0为文件或其他命令的输出) 输出文件-标准输出 1(缺省为屏幕;1为文件) 错误

第三章 shell学习之正则表达式

正则表达式 \<the\>:精确匹配the,不包括包含the的单词 [^b-d]:不包含b~d a\{2\}:a出现2次 a\{2,3\}:a出现2~3次 a\{2,\}:a至少出现2次 [:upper:]:大写字母(用的时候外面加一层[]表示匹配字符集合) [:lower:]:小写字母 [:digit:]:数字 [:alnum:]:大小写字母和数字 [:space:]:表示空格或tab键 [:alpha:]:大小写字母 通配 注意通配和正则表达式不同,虽然有共同的符号 ls -l *.sh

第四章 shell学习之sed命令和awk编程

sed命令 sed只是对缓冲区中原始文件的副本进行编辑,不改变源文件,所以要保存则要重定向到另一个文件 sed三种方式: 1.sed [选项] 'sed命令' 输入文件 2.sed [选项] -f sed脚本文件 输入文件 3../sed脚本文件 输入文件 其中3的sed脚本文件要以#! bin/sed -f等开头 选项: -n 不打印所有行到标准输出,默认先打印匹配的再打印所有 -e 关联多个sed命令 -f 调用sed脚本文件 定位文本: x x为指定行号 x,y 从x到y行 /patter

第五章 shell学习之文件的排序、合并和分割

sort命令 sort [选项] [输入文件] 选项: -c 测试文件是否已经排序,如果未被排序则输出第一个未被排序的记录 -k 指定排序的域 -m 合并两个已排序的文件,合并的文件也已经排序,如sort -m a1 a2,a1的记录被有序的插入a2 -n 根据数字的大小进行排序,一般放在域号后,如-k3n -o 将输出重定向到指定文件 -r 将排序结果逆向显示 -t 改变域分割符,如-t: -u 去除结果中的重复行 sort和awk联合 例: [[email protected] tmp]#

第六章 shell学习之变量和引用

变量 本地变量:类似于局部变量,只在当前shell进程有效 环境变量:适用于所有登录进程所产生的子进程 位置参数:用于向shell脚本传递参数,只读 变量替换和赋值 引用变量值就称为变量替换,$就为变量替换符号,如a为变量名则$a或${a}为变量值 将值赋给某个变量名就称为变量赋值,格式:variable=value或${ variable=value },如值中包含空格则必须用"" 清除变量的值: unset 变量名 设置只读变量: variable=value readonly v