首页 > 学院 > 操作系统 > 正文

Shell学习笔记

2024-06-28 13:23:51
字体:
来源:转载
供稿:网友
Shell学习笔记

都是一些零碎的知识,遇到什么写什么吧!

1、shell脚本参数

C用(int *argc, char *argv[])处理参数,python sys.argv[0](脚本名字)、sys.argv[1]、sys.argv[2]等表示各个参数,shell脚本自己处理命令参数的方式如下:

(1) $# 传递到脚本的参数个数,不包括脚本命令本身。如判断参数是否是2个:

   #!/bin/bash   if [ $# != 2 ]; then                                                                                                                          echo "Error! should need 2 parameters!"       exit 1   fi

(2) $0 脚本名字;$1,$2,......依次表示第一个参数,第二个参数,。。。。。。

(3) $* 以一个单字符串显示所有向脚本传递的参数,此选参数可超过9个。如:

若脚本参数为./test.sh arg1 arg2,则执行echo  $*,结果为:"arg1 arg2"

(4) $$ 脚本运行的当前进程ID号。

(5) $! 后台运行的最后一个进程的进程ID号。

(6) $@ 与$*相同,但是使用时加引号,并在引号中返回每个参数。如:

若脚本参数为./test.sh arg1 arg2,则执行echo  $*,结果为:"arg1""arg2"  与#*的差别,每个参数都是一个单独的字符串。

(7) $- 显示shell使用的当前选项,与set命令功能相同。(搞不懂)

(8) $? 显示最后命令的退出状态。 0表示没有错误,其他任何值表明有错误。如:

ls ./echo $?$?为0表示ls命令执行成功。

2、管道与重定向

管道操作符”|“,输出左边命令传出的正确输出信息,对与stderr信息没有直接处理能力。然后,传递给右边的命令,作为stdin。

要求:

(1) 管道命令只处理前一个命令正确输出,不处理错误输出;

(2) 管道命令右边命令,必须能够接收标准输入流命令才行。如cat test.txt | ls ,ls不支持stdin,左边的数据将被丢弃。

$ cat display.sh | lscall.py     libtest3.so  libtest.so    send_mail_text.py  test3.cpp  test4.cppdisplay.sh  libtest4.so  PRintfile.sh  test2.cpp          test3.so   test.c

重定向:

左边命令应该有标准输出 > 或者>> 右边只能是文件

左边命令应该有标准输入 < 或者<< 右边只能是文件

管道是触发了两个子进程执行"|"两边的程序,而重定向是在一个进程内执行。

3、shell与export首先要知道用户登录linux系统之后,系统会启动一个用户shell。在该shell下执行shell脚本,会创建一个子shell,子shell可以共享父shell的环境变量,父shell却不能共享定义在子shell中的环境变量。子shell中定义的环境变量只在该子shell中有效。

在shell中执行程序时,shell会提供一组环境变量,export可新增、修改和删除环境变量,供后续执行的程序使用。export设置的变量效用只在该次登录中有效。

语法:export [-fnp] [变量名称]=[变量设置值]

参数:

-f代表[变量名称中为]函数名称。

-n删除指定变量,实际上并未删除,只是不会输出到后续指令的执行环境中。

-p列出所有shell赋予程序的环境变量,默认参数。如:

Test@Ubuntu:~/code$ export   //等同 export -pdeclare -x HOME="/home/Test"declare -x LANG="zh_CN.UTF-8"declare -x LANGUAGE="zh_CN:en_AU:en_CA:en_GB:en_NZ:en_US:en"declare -x LC_ADDRESS="zh_CN.UTF-8"/*中间省略*/declare -x TERM="linux"declare -x USER="Test"declare -x XDG_RUNTIME_DIR="/run/user/1000"declare -x XDG_session_ID="1"
</pre><pre name="code" class="plain">Test@ubuntu:~/code$ export mytest="Hi"
<pre name="code" class="plain">Test@ubuntu:~/code$ export declare -x HOME="/home/Test"declare -x LANG="zh_CN.UTF-8"declare -x LANGUAGE="zh_CN:en_AU:en_CA:en_GB:en_NZ:en_US:en"declare -x LC_ADDRESS="zh_CN.UTF-8"/*中间省略*/declare -x TERM="linux"declare -x USER="Test"declare -x XDG_RUNTIME_DIR="/run/user/1000"declare -x XDG_SESSION_ID="1"declare -x mytest="Hi"

Test@ubuntu:~/code$ export -n mytestTest@ubuntu:~/code$ export declare -x HOME="/home/Test"declare -x LANG="zh_CN.UTF-8"declare -x LANGUAGE="zh_CN:en_AU:en_CA:en_GB:en_NZ:en_US:en"declare -x LC_ADDRESS="zh_CN.UTF-8"/*中间省略*/declare -x TERM="linux"declare -x USER="Test"declare -x XDG_RUNTIME_DIR="/run/user/1000"declare -x XDG_SESSION_ID="1"

因为export添加的环境变量是临时有效,要想永久有效就得添加到文件中:

(1)在/etc/profile文件中添加变量,对所有用户永久有效。例如:
#vi    /etc/profileexport CLASSPATH=./java_HOME/lib;$JAVA_HOME/jre/libexport PATH="$PATH:/home/Test"    //在原PATH变量上添加数据
<span style="font-family: Arial, Helvetica, sans-serif;">注:修改文件后要想马上生效还要运行source /etc/profile,不然只能在下次重进此用户时生效。</span>
(2)在用户目录下的.bash_profile(该文件在不同的linux系统下,文件名不同,有的是.profile,基本以profile结尾,可以用man bash查询)文件中添加环境变量,对该用户永久有效。用法跟上面相同。关于source,用法为:source FileName,作用是在当前bash环境下读取并执行FileName中的命令,该FileName可以没有执行权限。注意该命令中的脚本是在当前bash环境下执行,没有产生子shell,所以脚本添加的变量也能被当前shell所共享,跟直接执行脚本产生子shell不太一样。如同样的脚本Test.sh:
#!/bin/bash     export mytest="Hi"
用source Test.sh方式执行,mytest环境变量就可以添加到当前shell环境中,./Test.sh方式直接执行则不能。另外,source命令常用“.”来代替。source Test.sh与 . Test.sh等效。:


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表