shell 编程笔记

时间:2022-10-12 01:59:36

#! /bin/sh

寻找shell解释器 /bin/sh  是一个路径

#! /usr/bin/python

仅仅是寻找一个python的解释器





执行linux程序的方法:

使得文件具有可执行的权限 直接执行

调用解释器来运行

使用source来运行

shell 存在着内部命令 和外部命令 内建命令就是shell 程序本身的命令

运行内部命令的时候 不包含进程的创建和消亡

可是在运行外部命令的时候,存在着进程是创建和消亡。以此同一时候

外部命令运行的步骤例如以下:、

创建一个子进程

查找路径

子进程运行 父进程休眠

子进程运行完成。父进程从终端读取下一条命令





source 命令的运行不会 创建进程 更加的不会有进程的消亡 没有子进程

仅仅有在父进程中运行。





比如:echo.sh

#! /bin/sh

cd /tmp

echo "hello world"

运行方法选择的是 赋予权限的方式的话 ./echo.sh 此时父进程接受命令 发现不是内建命令 就会创建一个子进程(和父进程一模一样)来运行这个外部命令 此时子进程 来设置自己的环境变量 cd 命令改变的仅仅是子进程的文件夹 并没有改变父进程的文件夹 。子进程运行完毕 消亡,父进程等待下个命令运行 所以此方式下的运行 cd命令会失效。

所以选择的运行方式 是source的形式 就会运行 source不会创建子进程 仅仅是在父进程中进行。

shell变量:

全局变量 环境变量 自己定义变量

局部变量 必须使用local声明 否则还是全局可见的

export 用于设置当前的环境变量  





计算机 不能直接理解高级语言 须要将高级语言 翻译成机器语言 计算机才干看的明确 翻译是方式有两种 一种是:编译 一种是:解释

编译型的语言 是在程序运行之前 须要一个专门的编译过程 ,仅仅做一次的编译,运行的时候不须要进行编译了 运行效率较高

解释型的语言 是在程序在运行的时候 运行一次 翻译一次 效率较低。

脚本參数的传递

參数的传递 能够将外部的值传递到脚本的内部函数中去,提高脚本的灵活性。

testfunc()

echo "$# parameters";

echo "$@";





testfunc a b c 

3 parameters 

a b c 

testfunc a "b c"

2 parameters

a b c 





shell中的变量是不区分类型的 都是字符串类型 shell变量中有3中:用户变量 位置变量 环境变量 





linux中shell变量$#,$@,$0,$1,$2的含义解释: 

变量说明: 

$$ 

Shell本身的PID(ProcessID) 

$! 

Shell最后执行的后台Process的PID 

$? 

最后执行的命令的结束代码(返回值) 有数值的情况下返回数值 成功返回0值 退出的状态0 表示正常退出 非0表示执行出现异常 

$- 

使用Set命令设定的Flag一览 

$* 

全部參数列表。如"$*"用「"」括起来的情况、以"$1 $2 … $n"的形式输出全部參数。

$@ 

全部參数列表。

如"$@"用「"」括起来的情况、以"$1" "$2" … "$n" 的形式输出全部參数。 

$# 

加入到Shell的參数个数 

$0 

Shell本身的文件名称 

$1~$n 

加入到Shell的各參数值。$1是第1參数、$2是第2參数…。 





启动文件:

/bin/login   读取/etc/passwd文件成功登录后,启动一个交互的shell

/etc/environment 环境变量 

假设须要对shell做全局性的设置 而且在每次的启动的时候 自己主动载入 能够将命令写入启动文件里去





type用于显示 命令是什么类型的 是外部命令 内建命令 别名...

shell 的函数

#! /bin/sh

# 数字相加





function add(){

let "sum=$1+$2"

return $sum

}

运行:

source add.sh 将函数从文件里读入 之后能够直接调用

add 3 7

echo $?

$? 保存是上一次的命令运行的返回值

7





shell的条件控制与流程





if condition

then 

statements

elif contition

then 

statements

else

statements

fi

shell里面的case语句 

case $1 in

-f) statements;;

-d) statements;;

esac 





for 循环语句

for name [in list]

do 

....

done

for file in `find . -iname "*.mp3"` //反单引號的作用就是将命令返回的结果作为字符串

do

mpg123 $file

done





无限循环 

path=$PATH

while true

do

if [-z $path]

then

break;

fi

ls -ld ${path%%:*}
//列出path中第一个文件夹

path=${path#*:}
//截取path中的第一个文件夹和冒号

done





Tips:

位置參数能够用shift命令左移。比方shift 3表示原来的$4如今变成$1。原来的$5如今变成$2等等,原来的$1、$2、$3丢弃,$0不移动。

不带參数的shift命令相当于shift 1。

很实用的 Unix 命令:shift。

我们知道。对于位置变量或命令行參数,其个数必须是确定的。

或者当 Shell 程序不知道其个数时,能够把全部參数一起赋值给变量$*。

若用户要求 Shell 在不知道位置变量个数的情况下,还能逐个的把參数一一处理,

也就是在 $1 后为 $2,在 $2 后面为 $3 等。在 shift 命令运行前变量 $1 的值在 shift 命令运行后就不可用了。

linux shell里面的正則表達式:

定义:

简而言之,正則表達式就是记录文本规则的代码。

正則表達式:元字符 

\b 代表着单词的开头或是结尾

\d 代表着数字 比如0\d{2}-\d{8} 意思就是 010-12345678

grep 查找文本

正則表達式中的元字符:

^ :行或者字符串開始

$ :行或字符串结束

. :匹配一个非换行符的字符

* :匹配0个或多个先前字符 .* 代表随意字符

[...] :方括号表达式 [0-9]匹配单个数字 ^位于括号表达式的开头表示相反的意思[^0-9]不是0-9之间的数字

\ :打开或者关闭兴许字符

正則表達式:基本正則表達式 和扩展正則表達式

\(\): 

\n:

x\{m,n\}: 区间表达式 x出现的次数 最少m次 最多n次 

+: 匹配前面正則表達式的一个或者多个实例

?

: 匹配前面正則表達式的一个或者0个实例

():用括号括起来的正則表達式

|: 匹配|前面或者后面的正則表達式





grep支持的元字符

\<: 单词的開始

/>: 单词的结束

\w: 匹配文字或是数字 [:alnum:]

\W: 匹配非文字或是数字 [[:alnum:]_]

\b: 单词的锁定符





字符集:

[:alnum:]: 文字数字字符集 A-Za-z0-9

[:alpha:]: 文字字符集

[:blank:]: 空格或者定位字符

[:digit:]: 数字字符

[:graph:]: 非空字符

[:lower:]: 小写字符

[:cntrl:]: 控制字符

[:print:]: 非空字符

[:punct:]: 标点符号

[:space:]: 空白字符

[:upper:]: 大写字符

[:xdigit:]: 十六进制数字 0-9 a-f A-F





正則表達式里面的反向引用:

\(ab\)\(cd\)[efg]*\1\2 用来匹配: abcdabcd abcdeabcd abcdfabcd abcdgabcd \1: ab \2: cd 

\(go\).*\1 用来匹配一行出现了2个go

交替 | you|me 用来匹配 you 或者 me 交替的优先级是最低的

分组() (go)+ 匹配了一个go 或者是多个go 





罗马数字:

I=1

V=5 

X=10

L=50

C=100 CD=400 DC=600

D=500

M=1000 MCM=1900