shell是一个命令行解释器,它接收应用程序/ 用户命令,然后调用操作系统内核;功能强大的编程语言;

1. Shell解析器

Linux提供的Shell解析器有:

[kris@hadoop datas]$ cat /etc/shells
/bin/sh
/bin/bash
/sbin/nologin
/bin/dash
in/tcsh
/bin/csh

bash和sh的关系

[kris@hadoop bin]$ ll | grep bash
-rwxr-xr-x. root root 5月 bash
lrwxrwxrwx. root root 9月 sh -> bash

Centos默认的解析器是bash

[kris@hadoop datas]$ sh helloWorld.sh      bash helloWorld.sh 

2. Shell脚本

脚本的常用执行方式
第一种:采用bash或sh+脚本的相对路径或绝对路径(不用赋予脚本+x权限)
sh helloworld.sh
第二种:采用输入脚本的绝对路径或相对路径执行脚本(必须具有可执行权限+x)
[kris@hadoop datas]$ chmod +x helloWorld.sh
[kris@hadoop datas]$ ./helloWorld.sh

注意:第一种执行方法,本质是bash解析器帮你执行脚本,所以脚本本身不需要执行权限。第二种执行方法,本质是脚本需要自己执行,所以需要执行权限。

多命令处理

把内容输出到文件:
[kris@hadoop datas]$ cat batch.sh //脚本的内容如下:
#!/bin/bash cd /home/kris
touch cls.txt
echo "I love cls" >>
cls.txt
[kris@hadoop datas]$ sh batch.sh
[kris@hadoop datas]$ cat cls.txt
I love cls

3. Shell中的变量

1. 常用系统变量

$HOME、$PWD、$SHELL、$USER等

显示当前Shell中所有变量:set

自定义变量

[kris@hadoop datas]$ A=  //定义变量
[kris@hadoop datas]$ echo $A [kris@hadoop datas]$ A= //重写赋值
[kris@hadoop datas]$ echo $A [kris@hadoop datas]$ unset A //撤销
[kris@hadoop datas]$ echo $A [kris@hadoop datas]$ readonly b= //变量是只读,不能重新赋值
[kris@hadoop datas]$ echo $b 在bash中,变量默认类型都是字符串类型,无法直接进行数值运算
变量的值如果有空格,需要使用双引号或单引号括起来
可把变量提升为全局环境变量,可供其他Shell程序使用
  export 变量名
[kris@hadoop datas]$ vim helloWorld.sh
#!/bin/bash
echo "Hello World"
echo $a
[kris@hadoop datas]$ sh helloWorld.sh
Hello World          //发现并没有打印变量a的值
[kris@hadoop datas]$ export a
[kris@hadoop datas]$ sh helloWorld.sh
Hello World
I love kk
[kris@hadoop datas]$ sh helloWorld.sh
Hello World
I love kk

4. 特殊变量 $n、$*、$@、$?

$n    (功能描述:n为数字,$0代表该脚本名称,$1-$9代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如${10})

[kris@hadoop datas]$ vim parameter.sh
#!/bin/bash
echo "$0 $1 $2 $3"
echo $#
[kris@hadoop datas]$ sh parameter.sh Hello World java
parameter.sh Hello World java 十以上的参数需要用大括号包含,如${}

$* (功能描述:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)
$@ (功能描述:这个变量也代表命令行中所有的参数,不过$@把每个参数区分对待)
$*和$@都表示传递给函数或脚本的所有参数,不被双引号“”包含时,都以$1 $2 …$n的形式输出所有参数。
当它们被双引号“”包含时,“$*”会将所有的参数作为一个整体,以“$1 $2 …$n”的形式输出所有参数;“$@”会将各个参数分开,以“$1” “$2”…”$n”的形式输出所有参数。

[kris@hadoop datas]$ vim for3.sh
#!/bin/bash
for i in "$*" //不带" "的$*和$@;输出的结果是一样的,都是3行echo的内容;
do
echo "Hello hi java"
done
for j in "$@"
do
echo "你好"
done
[kris@hadoop datas]$ sh for3.sh
Hello hi java
你好
你好
你好

$? (功能描述:最后一次执行的命令的返回状态。如果这个变量的值为0,证明上一个命令正确执行;如果这个变量的值为非0(具体是哪个数,由命令自己来决定),则证明上一个命令执行不正确了。)

如何检查一个变量是否为空??

[kris@hadoop datas]$ [ $a ]
[kris@hadoop datas]$ echo $? [kris@hadoop datas]$ a="my life"
[kris@hadoop datas]$ echo $?

5. 运算符

基本语法
(1)“$((运算式))”或“$[运算式]”   一般都是用这种形式的
(2)expr + , - , *, /, % 加,减,乘,除,取余
注意:expr运算符间要有空格

[kris@hadoop datas]$ expr `expr  + ` \*
[kris@hadoop datas]$ echo $[(+)*]
[kris@hadoop datas]$ s=$[(+)*]
[kris@hadoop datas]$ echo $s [kris@hadoop datas]$ echo $(((+)*))

6. 条件判断

基本语法

[ condition ](注意condition前后要有空格)

注意:条件非空即为true,[ atguigu ]返回true,[] 返回false。

常用判断条件
()两个整数之间比较
= 字符串比较
-lt 小于(less than) -le 小于等于(less equal)
-eq 等于(equal) -gt 大于(greater than)
-ge 大于等于(greater equal) -ne 不等于(Not equal)
()按照文件权限进行判断
-r 有读的权限(read) -w 有写的权限(write)
-x 有执行的权限(execute)
()按照文件类型进行判断
-f 文件存在并且是一个常规的文件(file)
-e 文件存在(existence) -d 文件存在并是一个目录(directory) [kris@hadoop datas]$ [ -x /home/kris/datas/for.sh ]
[kris@hadoop datas]$ echo $? [kris@hadoop datas]$ [ -r /home/kris/datas/for.sh ]
[kris@hadoop datas]$ echo $?

多条件判断

[kris@hadoop datas]$ [ $[%] =  ] && echo yes || echo no  多条件判断;
yes

 判断一个文件是否存在

[kris@hadoop100 datas]$ vim exists.txt
#!/bin/bash
if [ -f chengji.txt ]; then ######## -f文件存在并且是常规文件; -e文件存在; -d文件存在且是个目录
echo "文件存在"
else
echo "文件不存在"
fi

1、由单引号括起来的字符都作为普通字符出现。特殊字符用单引号括起来以后,也会失去原有意义,而只作为普通字符解释。如例程中的 '-1 day',再比如:

[kris@hadoop101 ~]$ string='$PATH'
[kris@hadoop101 ~]$ echo $string
$PATH

可见$保持了其本身的含义,作为普通字符出现。

2、由双引号括起来的字符,除$(美元符号)、\(反斜杠)、(单引号)、和(双引号)这几个字符仍是特殊字符并保留其特殊功能外,其余字符仍作为普通字符对待。对于“$”来说,就是用其后指定的变量的值来代替这个变量和$;

[kris@hadoop101 ~]$ string="$PATH"
[kris@hadoop101 ~]$ echo $string
/usr/lib64/qt-3.3/bin:/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/sbin:/opt/module/jdk1..0_144/bin:/opt/module/hadoop-2.7./bin:/opt/module/hadoop-2.7./sbin:/opt/module/jdk1..0_144/bin:/opt/module/hadoop-2.7./bin:/opt/module/hadoop-2.7./sbin:/opt/module/jdk1..0_144/bin:/opt/module/hadoop-2.7./bin:/opt/module/hadoop-2.7./sbin:/opt/module/jdk1..0_144/bin:/opt/module/hadoop-2.7./bin:/opt/module/hadoop-2.7./sbin:/home/kris/bin

对于“\”而言,是转义字符,它告诉shell不要对其后面的那个字符进行特殊处理,只当作普通字符即可。可以想见,在双引号中需要在前面加上“\”的只有四个字符$,\,’和”本身。而对”号,若其前面没有加“\”,则Shell会将它同前一个”号匹配。如例程中的"-$i day",会随着循环,将$i转换成其代表的值。

3、反引号(`)这个字符所对应的键一般位于键盘的左上角,不要将其同单引号(’)混淆。反引号括起来的字符串被shell解释为命令行,在执行时,shell首先执行该命令行,并以它的标准输出结果取代整个反引号(包括两个反引号)部分。如例程中的`date -d '-1 day' +%Y%m%d`就是把这条命令的结果赋给变量OPDATE。

shell基本用法的更多相关文章

  1. Shell常见用法小记

    shell的简单使用 最近发现shell脚本在平常工作中简直算一把瑞士军刀,很多场景下用shell脚本能实现常用的简单需求,而之前都没怎么学习过shell,就趁机把shell相关的语法和常见用法总结了 ...

  2. Linux shell ${}简单用法

    转自:Linux shell ${}简单用法 为了完整起见,我这里再用一些例子加以说明 ${ } 的一些特异功能:假设我们定义了一个变量为:file=/dir1/dir2/dir3/my.file.t ...

  3. shell eval用法

    转自:http://blog.csdn.net/w_ww_w/article/details/7075867 eval可读取一连串的参数,然后再依参数本身的特性来执行.eval是shell内建命令,可 ...

  4. shell 函数用法

    近期在学习shell编程方面的知识,写的不怎么好,请大家多多指点,下面给大家分享一下shell函数的用法. 我们为什么要用shell函数? 简单的说,函数的作用就是把程序多次调用相同的代码部分定义成一 ...

  5. [shell]shell 中| && || () {} 用法以及shell的逻辑与或非

    转自:https://www.jianshu.com/p/617c1ee1e46e | 运算符 管道符号,是unix一个很强大的功能,符号为一条竖线:"|".用法: command ...

  6. shell简单用法笔记(shell中数值运算)二

    shell中变量值,如果不手动指定类型,默认都是字符串类型: 例如: a= b= c=$a+#b echo $c 结果会输出:123+456 shell中,如果要进行数值运算,可以通过一下方法: 方法 ...

  7. shell简单用法笔记(一)

    一.linux中主要用的bash shell:查看linux系统中支持的shell种类可用: vim /etc/shell 执行shel脚步的方式: 1.赋予脚步可执行权限,使用相对或绝对路径调用该脚 ...

  8. shell expr用法

    expr 计算整数变量值 使用方法如下: linux-zpycfm:/home/test/shell # s=+ -bash: +: command not found linux-zpycfm:/h ...

  9. shell -- sed用法

    sed是一个很好的文件处理工具,本身是一个管道命令,主要是以行为单位进行处理,可以将数据行进行替换.删除.新增.选取等特定工作,下面先了解一下sed的用法sed命令行格式为:         sed ...

随机推荐

  1. jq获取页面url后边带的参数

    //获取url后边的参数 $.getUrlParam = function (name) {                  var reg = new RegExp("(^|&) ...

  2. Confluence 6 临时目录(安装目录)

    temp 目录是由 Java 运行时进行配置的,同时一些 Confluence 的组件将会写入历史文件或者锁定文件到这个目录中. 临时目录位于安装目录下的 /temp 目录中. 希望修改这个目录的位置 ...

  3. Confluence 6 Oracle 测试你的数据库连接

    在你的数据库设置界面,有一个 测试连接(Test connection)按钮可以检查: Confluence 可以连接你的数据库服务器 数据库的字符集编码是否正确 你的数据库用户是否具有需要的权限 你 ...

  4. gnuradio 使用eclipse 编辑器记录

    第1步 - 首先安装eclipse 先去官网下载,然后解压  --->下载版本是C++/C 版---->解压--->打开--->help->eclipse marketp ...

  5. GitHub搭配使用Travis CI 进行自动构建服务

    Travis CI (Continuous Integration)持续集成服务 用处:自动监控软件仓库,可以在代码提交后立刻执行自动测试或构建 1.在Github自己的仓库根目录里添加.travis ...

  6. Python基础之常用模块

    一.time模块 1.时间表达形式: 在Python中,通常有这三种方式来表示时间:时间戳.元组(struct_time).格式化的时间字符串: 1.1.时间戳(timestamp) :通常来说,时间 ...

  7. 第八周学习总结-C#、C++

    2018年9月2日 今天是小学期开始第三天,本周前几天看了看C#和C++,用C#窗体做了个计算器,然后还用Scratch做了一个贪吃蛇的脚本. 31号小学期开始,到今天我把A类基本做完了.一开始做通讯 ...

  8. linux安装MongoDB

    安装 32bit的mongodb最大只能存放2G的数据,64bit就没有限制 到官网,选择合适的版本下载,本次下载3.4.0版本 解压 tar -zxvf mongodb-linux-x86_64-u ...

  9. 论文阅读笔记二十五:Spatial Pyramid Pooling in Deep Convolutional Networks for Visual Recognition(SPPNet CVPR2014)

    论文源址:https://arxiv.org/abs/1406.4729 tensorflow相关代码:https://github.com/peace195/sppnet 摘要 深度卷积网络需要输入 ...

  10. IDEA中tomcat的部署

    创建一个项目就要部署tomcat