Shell 基础

Shell中有三种引号,分别为双引号(" ")、单引号(' ')以及反引号(` `)
其中双引号对字符串中出现的$、''、`和\进行替换;单引号不进行替换,将字符串中所有字符作为普通字符输出,而反引号中字符串作为shell命令执行,并返回执行结果。具体含义如下:

双引号(" "):在双引号中,除了$, '', `和\以外所有的字符都解释成字符本身。
单引号(' '):在单引号中所有的字符包括特殊字符($,'',`和\)都将解释成字符本身而成为普通字符。
反引号(` `):在反引号中的字符串将解释成shell命令来执行。

例如

$ a=1
$ echo $a
1
$ echo 'this is $a' #单引号 this is $a
$
echo "this is $a" #双引号 this is 1

  $ a=`ls` 
  $ echo $a  #反引号,显示执行ls命令后的结果

 

使用变量与其它字符连接时,可以如下如下使用
$ echo ${a}_2
1_2

 

一些快捷操作命令
$PWD
$USER
$HOME
$PATH

$ pwd  #返回当前的目录路径
$ echo $PWD     #返回当前的目录路径
$ echo $USER   #返回当前用户名
$ echo $HOME  #返回当前的目录路径 等价于 $ echo ~
$ echo $PATH   #返回当前的环境变量的内

$ echo $$  #查看当前的进程的ID
$ () 在括号中执行的的子 shell,相当于函数的作用域。而 {} 执行的是当前的语句块
$ (a=1)
$ echo $a   #不会显示 1

$ for ((i=0;i<5;i++));do echo $i;sleep 2;done &   #每两秒操作操作一次字符,而最后的 “&”字符表示该操作在后台进行,且不影响当前界面进行其他操作

$ echo $!   #返回当前进程的最后一个进程的 ID

$ jobs   #显示当前进程的状态

 

按键盘 CTRL+Z ,会把当前正在执行的进程暂停,然后放到后台,按 CTRL+Z 后,程序会给被暂停的进程一个标识号。若想把被暂停的进程调回来继续执行,

使用命令  bg  +  标识号;若被调到后台的进程想调到前台,使用命令  fg + 标识号

 

> 输出重定向,可以把内容输出到文件中,但是会覆盖文件中原来的内容;
>> 输出重定向,可以把内容输出到文件中,不会覆盖文件中原来的内容,而是追加输入到文件中

$ echo "hello" > file  #将字符串“hello”输出到文件file 中
$ echo "hello" >> file  #将字符串“hello”追加输出到文件file 中

< 输入重定向,可以把文件的内容输入到一个变量上,

$ resd x < file   #把file 文件中的内容输入到x (read 命令一次读取一行)
$ echo $x
testerhome

 

$ ls ddd > a 2>&1    #前提,已建立了文件a,2代表当前的标准错误输出,1代表标准输入。

2>&1 该命令的意思:将ddd输入到文件中,若报错,将报错信息也输入到文件a中,若正常执行,则将正常执行的结果输入到文件a中;2>&1 该命令是一个固定模式,不能修改

 

ls 命令

$ ls -l  #显示当前目录下的文件具体信息,如权限、大小、创建时间、文件名字等,可以简写为 $ ll
$ ls -al  #显示当前目录下的文件具体信息,包含了隐藏文件一起显示

 

$ which  #加文件名 例如 $ which python 是从当前的环境变量中查找该文件的安装位置
$ export PATH=$PATH:$PWD  #把当前的目录的添加到当前的系统变量中

数组处理

$ array=(1 2 3 4 5)
$ echo ${array[@]}  #@不管加不加双引号,都当做数组处理
1 2 3 4 5
$ echo ${array[*]}  # * 当加上双引号时, 把数组中的值都当做字符串处理
1 2 3 4 5
$ echo ${#array[@]} #返回数组中有多少个元素
5
$ echo ${array[2]} #通过数组下标索引输出元素
3

  

 

  

 

cd 命令,进入目录
$ cd expert/  #进入expert/目录
$ cd ..   #回到上一层目录
$ cd   #回到根目录

 

特殊字符处理

$ echo -e "a\nbb"   #-e 开启转义功能,不开启,输出的是 a\nbb
a
bb
$ echo $(())  #对变量进行操作
$ a=2;b=3
$ echo $((a+3))
5

(()) 把括号中的变量当做整数去处理

$ a=1;b=3
$ (($a>$b));echo $?
1

echo $? 表示上一个语句是否执行正确,返回响应的值,在bash中,0代表true,所有非0的代表false
注意,针对的是上一个语句,整个表达式的执行

 

seq 命令,给定初始值和终值,构建一串序列

 

字符串操作

$ s="hello from testerhome"
$ echo ${s:6} #从字符串的第六个字符开始输出,类似python的切片
from testerhome 
$ echo ${s:6:3} #截取从字符串的第六个字符开始,到后面的第三个字符,然后输出
fro
$ echo ${s#hello}  #将指定的字符/字符串去掉(默认包含了前后空格,从头部开始匹配),然后输出
from testerhome
$ echo “${s#hello}”  #将指定的字符/字符串去掉(加双引号不包含前后空格),然后输出
from testerhome
$ echo ${s#*m}  #采用了正则匹配,*是通配符,代表任意字符,m只匹配一次(非贪婪匹配)
testerhome
$ echo ${s##*m}  #采用了正则匹配,*是通配符,代表任意字符,m匹配多个(贪婪匹配)
e
$ echo ${s%home}  #将指定的字符/字符串去掉(默认包含了前后空格,从尾部开始),然后输出
hello from tester
$ echo ${s%h*}  #采用了正则匹配,*是通配符,代表任意字符,h只匹配一次(非贪婪匹配),从尾部开始匹配
hello from tester
$ echo ${s/from/to}  #替换字符串,第一个斜杠后边是被替换的字符,第二个斜杠后边是要替换的字符,只匹配到识别的第一个字符。贪婪匹配模式可以参照上面的例子。
hello to testerhome

 

字符串比较

$ a=testerhome
$ b="testerhome"
$ [ "$a" = "$b"]
$ echo $?
1
$ [ "$a" != "$b"]
0
$ [ -n $a]  #如果字符串不为空,则结果为真 
$ echo $?
0
$ [ -z $a]  #如果字符串为空,则结果为真 
$ echo $?
1

 

字符串替换

${变量/查找/替换值} 一个“/”表示替换第一个,”//”表示替换所有,当查找中出现了:”/”请加转义符”\/”表示。

$ test='c:/windows/boot.ini'
$ echo ${test/\//\\}
c:\windows/boot.ini
$ echo ${test//\//\\}
c:\windows\boot.ini
$ x=abcdabcd
$ echo ${x/a/b} # 只替换一个
bbcdabcd
$ echo ${x//a/b} # 替换所有
bbcdbbcd
#举例
$ test='liu.'
$ echo ${test//'.'/'\.'}
liu\.

#使用 awk 或 sed 命令表示
$ a="1234567"
$ echo $a | awk '{print substr($0,2,3)}'
234
$ echo $a | sed 's/3/c/g' # g 表示进行全局匹配
12c4567

 

 

 

grep 命令详解

 

grep [OPTIONS] "PATTERN" [FILE...]
Options:
    -E, --extended-regexp  # equal to "egrep"
    -i, --ignore-case      # 忽略大小写
    -n, --line-number      # 显示行号
    -v, --invert-match   
    -o, --only-matching    # show only the part of a line matching PATTERN,精准匹配
    -r "PATTERN" DIR    # 根据文件内容, 查找文件
    -A NUM, --after-context=NUM
    -B NUM, --before-context=NUM
    -C NUM, --context=NUM
    --color

 

“|” 管道命令

管道前面是内容,管道后面是命令,前面命令的输出作为'|'后面的输入
$ echo adbc | grep -o c 前面的 adbc 通过后面的精准匹配 c 符号,然后输出
c

 

双竖线‘||’,用双竖线‘||’分割的多条命令,执行的时候遵循如下规则,如果前一条命令为真,则后面的命令不会执行,如果前一条命令为假,则继续执行后面的命令。可以表示为“或”

“&” 同时执行多条命令,不管命令是否执行成功

“&&” 可同时执行多条命令,当碰到执行错误的命令时,将不再执行后面的命令。如果一直没有错误的,则执行完毕。

 

curl 命令

status=$(curl -I -m 10 -o /dev/null -s --head -w %{http_code} $url)
status=$(curl -s --head $url | head -n 1 | awk '{print $2}')

以上两句都是匹配某个 URL 进行请求后返回的状态码,并赋值给 status 变量,部分命令解释:

# -I 只显示http response的头信息
# -m 10 最大传输时间10s
# -o /dev/null 屏蔽原有输出信息
# -s silent 模式,不输出任何东西
# -w %{http_code} 控制额外输出
# --head 显示http response的头信息,不包含网页代码
# head -n 1 指定需要输出的文本行数量

 

posted @ 2019-07-07 11:30  chenzy01  阅读(174)  评论(0编辑  收藏  举报