赞
踩
3
使用| 可以将多个命令拼接在一起
cat /etc/passwd | grep itcast | cut -d: -f4
1000
原理:将前一个命令的标准输出作为后一个命令的标准输入
标准错误输出是不会被管道传递的
cp | grep information. # 这个是不生效的
cp --help | grep existing --color #这个是正确用法
并不是所有的命令都可以接受|的数据,比如说ls
find ../../01-shell-basic/ | ls
需求:实现一个接收管道输出的命令:读取标准输入,将标准输入的数据转成大写,然后输出:
#include<stdio.h>
#include<ctype.h>
int main()
{
int ch=getchar();
while(ch != EOF)
{
putchar(toupper(ch));
ch = getchar();
}
return 0;
}
经常与more和less使用
作用之一:
将标准输出重新输出到指定的文件
公司服务器打印log,希望能够在屏幕上打印,同时保存到文件:
ping www.baidu.com | tee ping.log
如果想动态查看ping.log文件内容
作用之二:
当修改了一个文件很多内容,但是没有修改权限的时候,可以直接使用tee命令来激活sudo 权限,从而完成修改
cmd > 1.txt , 将输出写入到1.txt,每一次都是重新覆盖,等同于: cmd 1> 1.txt(常用)
cmd > > 1.txt,将输出追加到1.txt
>, >> 两者只能将标准输出重定向到文件,而标准错误输出无法直接写入
案例:
$ cp > cp.txt
cp: missing file operand
Try 'cp --help' for more information.
cat cp.txt 返回空
文件描述符:
如果想将错误的信息重定向到文件,需要使用文件描述符2
cp 2> cperr.txt #2> 表示对错误信息重定向
如何将正确输出和错误输出都写入到一个文件中?(最常用)
cp > /tmp/cperr1.txt 2>&1
写一段c代码,里面同时输出:stdout, stderr
#include<stdio.h>
int main()
{
//写一段c代码,里面同时输出:stdout, stderr
fprintf(stdout, "this is stdout\n"); //fd 1
fprintf(stderr, "this is stderr\n"); //fd 2
return 0;
}
结果:
使用重定向进行输入
cmd < file
cat < /etc/passwd
其他:
没有参数列,没有返回值,return返回的是状态码,使用$?查看
定义函数:
function test1() { #这个return的值,表示这个函数之后之后返回的状态码,而不出返回值, #不能通过a=test()来获取100值 #可以通过echo $?来获取 return 100 } #function去掉 test() { } #去掉括号 function test { } #function和()至少保留一个,否则无法识别成函数ss
案例:
#!/bin/bash function test1() { a=200 #a=100 #这个return的值,表示这个函数之后之后返回的状态码,而不出返回值, #不能通过a=test()来获取100值 #可以通过echo $?来获取 if [ $a -eq 100 ]; then return 0 else echo "hello test1" return 100 fi } #function去掉 test2() { echo "hello test2" } #去掉括号 function test3 { echo "hello test3" #如果函数没有return值,那么最后一条执行命令的状态码,就是这个函数的状态码 } #function和()至少保留一个,否则无法识别成函数ss v1=`test1` if [ $? -eq 0 ];then echo "test1执行成功! a=100" else echo "test1执行之后,a!=100" fi #echo "test1 的返回状态码:" $? #echo "v1 : " "$v1" test2 test3
小结:
执行状态$?看return的返回值,如果没有返回值,则以最后一条命令的返回值为准
test2()
{
echo "hello test2"
cp #echo $? 1
}
return修饰的状态码只能是数字
function test3
{
echo "hello test3"
#./functest.sh: line 26: return: beijing: numeric argument required
return "beijing" #这是错误的用法,必须是数字
}
函数参数:
调用方法与命令一样,也是$1, $2 …
test4()
{
echo "test4 函数参数为: $1, $2"
}
test4 "hello" "world"
案例:递归遍历指定目录的文件!
#!/bin/bash #案例:递归遍历指定目录的文件! #目录由用户通过命令行传入: #./recursive.sh .. recursive() { #接收用户输入的目录 #currDir="$1" local currDir="$1" echo "====> 当前目录为:" "$currDir" #遍历当前目录 for i in `ls $currDir` do #这样才是有效的路径,后续才能正确判断性质 #item="$currDir+"/"+$i" <<=== 这是错误的, /usr/+/+test.txt item="$currDir/$i" #echo "item: " $item #如果i是文件,则打印 if [ -f "$item" ]; then echo "文件找到: $item" elif [ -d "$item" ];then #如果i是文件夹,则递归遍历 echo "文件夹找到:" "$item" recursive $item else echo "未知文件:" "$item" fi done } #判读输入参数的个数 if [ $# -ne 1 ];then echo "Usage: recursive <文件目录>" exit fi recursive $1
shell调试参数:
-n 帮助我们快速检查脚本的语法,而不是逐条执行
脚本如果很大,中间执行过程很长,如果不能实现发现脚本错误,会浪费时间
bash -n ./recursive.sh
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Z8qiFsCW-1618819377024)(assets/1585713051107.png)]
-x,执行脚本的同时将代码执行过程打印到屏幕,便于追踪
bash -x recursive.sh ==》 作用于整个脚本
可以在代码中,对指定的代码段进行调试
set -x ==> 启动调试
xxxx
set +x ==> 停止调试
shift 8 ==> *, 快速定位当前光标所值单词(向下寻找,n)
shift 3 ==> #, 快速定位当前光标所值单词(向上寻找,n)
以S开头的字符串
^: 可以限定一个字符开头
目标:ShelloShello world
表达式:^Shello
以数字结尾的字符串
$:可以限定结尾
表示数字方式:
目标:helloworld9
表达式:helloworld[0-9]$
匹配空字符串(没有任何字符)
字符串只包含三个数字
字符串只有3到5个字母
匹配不是a-z的任意字符
^ 在[]内部的时候,表示取反(注意,不是限定开头)
[0-9] : 以非数字开头的字符
内反,外头
[^a-z] <<<===
字符串有0到1个数字或者字母或者下划线
表示0-1的方法
[a-zA-Z0-9_]?
内容
hello
hello1
hello*
正则:
hello[a-zA-Z0-9_]?
匹配结果:
hello
hello1
hello
字符串有1个或多个空白符号(\t\n\r等)
\s ==》 代表空格
+:一个或多个
内容:hello world
正则:hello\s+world
结果:hello world
字符串有0个或者若干个任意字符(除了\n)
.: 点,代表任意字符,除了\n
*:星号,重复前一个字符0-n次
匹配任意字符,任意次数:通常做法,是: .* ==> 相当于通配符里面的 *
内容:hello asdfaasdfasdfadfasdfasdf asdfasdfasdf world
正则:hello.*world
结果:hello asdfaasdfasdfadfasdfasdf asdfasdfasdf world
.{,} ==> 与 .*效果相同
小结:
匹配0或任意多组ABC,比如ABC,ABCABCABC
字符串要么是ABC,要么是123
(ABC|123)
内容:
ABC
ABCABCABCD
123456
hellowlrd
正则:(ABC|123)
字符串只有一个点号
匹配十进制3位整数 :
匹配0-255的整数, ip地址
^(([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\.){3}([0-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])$
匹配端口号
[\w!#$%&'*+/=?^_`{|}~-]+(?:\.[\w!#$%&'*+/=?^_`{|}~-]+)*@(?:[\w](?:[\w-]*[\w])?\.)+[\w](?:[\w-]*[\w])?
三种正则表达式:
基础正则:(不使用) ==》 +?* 都当成普通字符来处理
扩展正则:(我们默认使用这个)==》 +?* 当成特殊字符
Perl正则:
+?*是特殊字符
\d ==》 数字 [0-9]
\w ==> 字符[a-zA-Z]
用法\d{3}\w 可以匹配:212c
-f 忽略字符大小写
-n 按照数值比较
-t 分割字符
-k 指定分割之后比较的字段
-u 只显示一次
-r 反向排序
使用:分割之后,截取第三段,以数字的值进行比较,反向打印
sort passwd -t: -k3 -n -r
uniq.txt
xiaoliu 99 man 25
xiaowen 98 man 24
xiaoliu 99 man 25
去重方式,需要重复的两行挨着才能去重,一般和sort配合使用
cat uniq.txt | sort | uniq
-l: 统计文件的行数 <==最常用
-c:统计字符
-w:统计单词数量
duke ~$ wc /etc/passwd -l
32 /etc/passwd
duke ~$ wc /etc/passwd -c
1694 /etc/passwd
duke ~$ wc /etc/passwd -w
49 /etc/passwd
grep [options]
主要参数: grep --help可查看
-c:只输出匹配行的计数。
-i:不区分大小写。
-h:查询多文件时不显示文件名。
-l:查询多文件时只输出包含匹配字符的文件名。
-n:显示匹配行及 行号。
-s:不显示不存在或无匹配文本的错误信息。
-v:显示不包含匹配文本的所有行。
--color=auto :可以将找到的关键词部分加上颜色的显示。
-r: 表示递归查询
-i 忽略大小写,NOLOGIN一行也打印了
grep -i nologin passwd --color
使用拓展正则[0-9].*
grep -i "[0-9].*bin" passwd --color
如果想使用Perl正则,需要指定-P开关
grep -i -P "\d.*bin" passwd --color
使用-r进行递归查询
grep -i -P "\d.*bin" * --color -r
cat /etc/passwd | grep root
语法:
find pathname -options [-print -exec -ok ...]
find ./shell -name "*.txt"
find ./shell/ -perm 755
find ./shell -type f "*.txt" #文件类型
find ./shell/ -type d -name "*.txt" #文件夹类型
-type 查找某一类型的文件,诸如:
b - 块设备文件。
d - 目录。
c - 字符设备文件。
p - 管道文件。
l - 符号链接文件。
f - 普通文件。
find / -maxdepth 2 -type d
find ./shell -type f -iname "*.txt"
对find查找到的文件,进行处理,使用
-exec: 直接执行
find ./shell -type f -iname "*.txt" -exec rm {} \;
{} 替换为传入的数据
\; 表示命令结束
-ok:逐个确认
find ./shell -type f -iname "*.txt" -ok rm {} \;
按照日期查询
-atime : 访问时间
-mtime: 修改时间, 内容修改
-ctime: 不是创建时间,而是状态修改时间,权限,所有者
find ./shell/ -mtime +1
-1: -n表示在n天之内修改的
+1: +n表示在n天以前修改的
参数列表:
-name 按照文件名查找文件。 -perm 按照文件权限来查找文件。 -size n:[c] 查找文件长度为n块的文件,带有c时表示文件长度以字节计。 -depth 在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找。 -prune 使用这一选项可以使find命令不在当前指定的目录中查找,如果同时使用-depth选项,那么-prune将被 find命令忽略。 -user 按照文件属主来查找文件。 -group 按照文件所属的组来查找文件。 -mtime -n +n 按照文件的更改时间来查找文件,-n表示文件更改时间距现在n天以内,+n表示文件更改时间距现在 n天以前。find命令还有-atime和-ctime 选项,但它们都和-m time选项。 -nogroup 查找无有效所属组的文件,即该文件所属的组在/etc/groups中不存在。 -nouser 查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在。 -newer file1 ! file2 查找更改时间比文件file1新但比文件file2旧的文件。 -fstype 查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配 置文件中包含了本系统中有关文件系统的信息。 -mount 在查找文件时不跨越文件系统mount点。 -follow 如果find命令遇到符号链接文件,就跟踪至链接所指向的文件。
pathname: find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录,递归查找。
-print: find命令将匹配的文件输出到标准输出。
-exec: find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' {} \;,注意{}内部无空格,和\;之间含有一个空格分隔符。
-ok: 和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。只有用户明确输入y才会执行后边的语句
head、tail、scp、xargs、sed、awk
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。