尚硅谷Shell学习笔记

Shell

1、Shell的概述

Shell是一个命令行解释器,它接收应用程序/用户命令,然后调用操作系统内核

Shell还是一个功能相当强大的编程语言,易编写、易调试、灵活性强

2、Shell的解析器

  • Linux提供的解析器有:

    查看shell的解析器

    # 加sudo相当于有root权限
    sudo cat /etc/shells
    

    image-20220719144743422

  • bash与sh的关系

    image-20220719144937731

  • CentOS默认的解析器就是bash

    image-20220719145032969

3、Shell脚本入门

  1. 脚本格式

    脚本以 #!/bin/bash 开头(指定解析器)

  2. 第一个 Shell 脚本:helloworld

    (1)需求:创建一个Shell脚本,输出helloworld

    (2)实例实操:

    [root@KyServer datas]# touch helloworld.sh
    [root@KyServer datas]# vi helloworld.sh 
    

    helloworld.sh中输入以下内容:

    #!/bin/bash
    echo "helloworld"
    

    (3)脚本的常用执行方式

    第一种:采用bashsh + 脚本的相对路径或决定路径(不用赋予脚本+x权限)

    sh + 相对路径

    [root@KyServer datas]# sh helloworld.sh 
    helloword linux
    

    sh + 脚本绝对路径

    [root@KyServer datas]# sh /home/datas/helloworld.sh 
    helloword linux
    

    bash + 相对路径

    [root@KyServer datas]# bash helloworld.sh 
    helloword linux
    

    bash + 脚本绝对路径

    [root@KyServer datas]# bash /home/datas/helloworld.sh 
    helloword linux
    

    第二种:采用输入脚本的绝对路径或者相对路径执行脚本==(必须具有可执行权限+x)==

    (a)首先要赋予helloworld脚本的+x权限

    [root@KyServer datas]# chmod 777 helloworld.sh 
    

    (b)执行脚本

    相对路径

    [root@KyServer datas]# ./helloworld.sh
    helloword linux
    

    绝对路径

    [root@KyServer datas]# /home/datas/helloworld.sh 
    helloword linux
    

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

  3. 第二个 Shell 脚本:多命令处理

    (1)需求:

    在/home/datas/目录下创建一个 banzhang.txt,在 banzhang.txt 文件中增加"I love cls"

    (2)实例实操:

    [root@KyServer datas]# touch batch.sh
    [root@KyServer datas]# vim batch.sh
    

    batch.sh中写入以下内容

    #!/bin/bash
    
    cd /home/datas/
    touch banzhang.txt
    echo "I love cls" >> banzhang.txt
    

    (3)脚本执行

    [root@KyServer datas]# bash batch.sh 
    [root@KyServer datas]# ll
    total 12
    -rw-r--r-- 1 root root 22 Jul 19 15:42 banzhang.txt
    -rw-r--r-- 1 root root 82 Jul 19 15:42 batch.sh
    -rwxrwxrwx 1 root root 35 Jul 19 15:06 helloworld.sh
    [root@KyServer datas]# cat banzhang.txt 
    I love cls
    

4、Shell中的变量

4.1、系统变量

  1. 常用系统变量

    $HOME、$PWD、$SHELL、$USER

  2. 实际操作

    (1)查看系统变量的值

    [root@KyServer ~]# echo $HOME
    /root
    [root@KyServer ~]# echo $PWD
    /root
    [root@KyServer ~]# echo $SHELL
    /bin/bash
    [root@KyServer ~]# echo $USER
    root
    

    (2)显示当前Shell中所有的变量:set

    [root@KyServer ~]# set
    BASH=/bin/bash
    BASHOPTS=checkwinsize:cmdhist:expand_aliases:extquote:force_fignore:histappend:hostcomplete:interactive_comments:login_shell:progcomp:promptvars:sourcepath
    BASH_ALIASES=()
    BASH_ARGC=()....
    BASH_ARGV=()
    BASH_CMDS=()
    BASH_LINENO=()
    BASH_SOURCE=()
    ....
    

4.2、自定义变量

  1. 基本语法

    (1)定义变量:变量=值

    (2)撤销变量:unset 变量

    (3)声明静态变量:readonly 变量,注意:不能 unset

    [root@KyServer datas]# A=1		-给A赋值
    [root@KyServer datas]# echo $A
    1
    [root@KyServer datas]# A=2		-重新给A赋值
    [root@KyServer datas]# echo $A
    2
    [root@KyServer datas]# unset A	- 撤销变量
    [root@KyServer datas]# echo $A
    
    [root@KyServer datas]# readonly B=3		-设置静态变量
    [root@KyServer datas]# echo $B
    3
    [root@KyServer datas]# unset B		-不能撤销静态变量
    -bash: unset: B: cannot unset: readonly variable
    
  2. 变量定义规则

    (1)变量名称可以由字母、数字和下划线组成,但是不能以数字开头,环境变量名建议大写

    (2)等号两侧不能有空格

    (3)在bash中,变量默认类型都是字符串类型,无法直接进行数值运算

    [root@KyServer datas]# C=1+1
    [root@KyServer datas]# echo $C
    1+1
    

    (4)变量的值如果有空格,需要使用双引号或单引号括起来

    [root@KyServer datas]# D='A B C'
    [root@KyServer datas]# echo $D
    A B C
    

    (5)可把变量提升为全局变量,可供其他shell程序使用

    ​ 语法:export 变量

    [root@KyServer datas]# vim helloworld.sh
    
    在 helloworld.sh 文件中增加 echo $D
    #!/bin/bash
    echo "helloword linux"
    echo $D
    
    [root@KyServer datas]# ./helloworld.sh 
    helloword linux
    

    发现并没有打印输出变量B的值

    [root@KyServer datas]# export D
    [root@KyServer datas]# ./helloworld.sh 
    helloword linux
    A B C
    

4.3、特殊变量:$n

  1. 基本语法

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

  2. 案例实操

    (1)输出该脚本文件名称、输入参数1和输入参数2的值

    [root@KyServer datas]# vim parameter.sh
    
    在parameter.sh输入以下内容
    #!/bin/bash
    echo "$0 $1 $2"
    
    [root@KyServer datas]# chmod 777 parameter.sh 
    [root@KyServer datas]# ./parameter.sh 
    ./parameter.sh  
    [root@KyServer datas]# ./parameter.sh hh 4
    ./parameter.sh hh 4
    

4.4、特殊变量:$#

  1. 基本语法

    $#(功能描述:获取所有输入参数个数,常用于循环)

  2. 案例实操

    (1)获取输入参数的个数

    [root@KyServer datas]# vim parameter.sh
    
    在parameter.sh输入以下内容
    #!/bin/bash
    echo "$0 $1 $2"
    echo $#
    
    [root@KyServer datas]# chmod 777 parameter.sh 
    [root@KyServer datas]# ./parameter.sh hh 15
    ./parameter.sh hh 15
    2
    

4.5、特殊变量: ∗ 、 *、 @

  1. 基本语法

    $*(功能描述:这个变量代表命令行中的所有参数,$*把所有的参数看成一个整体)

    $@(功能描述:这个变量也代表命令行中的所有参数,不过$@把每个参数区别对待)

  2. 案例实操

    (1)打印输入的所有实操

    [root@KyServer datas]# vim parameter.sh
    
    在parameter.sh输入以下内容
    #!/bin/bash
    echo "$0 $1 $2"
    echo $#
    echo $*
    echo $@
    
    [root@KyServer datas]# bash parameter.sh hh jj kk
    parameter.sh hh jj
    3
    hh jj kk
    hh jj kk
    

4.6、特殊变量:$?

  1. 基本语法

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

  2. 案例实操

    (1)判断 helloworld.sh 脚本是否正确执行

    - 执行成功的情况
    [root@KyServer datas]# ./helloworld.sh 
    helloword linux
    A B C
    [root@KyServer datas]# echo $?
    0
    
    - 执行失败的情况
    [root@KyServer datas]# a ==
    -bash: a: command not found
    [root@KyServer datas]# echo $?
    127
    

5、运算符

  1. 基本语法

    (1)"$((运算式))"或"$[运算式]"

    (2)expr + , - , \* , / , %加 减 乘 除 取余

    注意:expr运算符间要有空格

  2. 案例实操

    (1)计算 3+2 的值

    [root@KyServer datas]# expr 3 + 2
    5
    

    (2)计算 3-2 的值

    [root@KyServer datas]# expr 3 - 2
    1
    

    (3)计算 (2+3)*4 的值

    ​ (a)expr一步完成计算

    [root@KyServer datas]# expr `expr 3 + 2` \* 4
    20
    

    ​ (b)采用$[运算式]方式

    [root@KyServer datas]# s=$[(2+3)*4]
    [root@KyServer datas]# echo $s
    20
    

6、条件判断

  1. 基本语法

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

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

  2. 常用判断条件

    (1)两个整数之间的比较

    符号描述
    -lt(less than)小于
    -le(less equal) 小于等于
    -eq(equal)等于
    -gt(greater than) 大于
    -ge(greater equal) 大于等于
    -ne(not equal) 不等于

    (2)按照文件权限进行判断

    • -r 有读的权限(read)
    • -w 有写的权限(write)
    • -x 有执行的权限(execute)

    (3)按照文件类型进行判断

    • -f 文件存在并且是一个常规的文件(file)
    • -e 文件存在(existence)
    • -d 文件存在并是一个目录(directory)
  3. 案例操作

    (1)23是否大于等于22

    [root@KyServer datas]# [ 23 -ge 22  ]
    [root@KyServer datas]# echo $?
    0
    

    (2)helloworld.sh是否有写权限

    [root@KyServer datas]# [ -w helloworld.sh ]
    [root@KyServer datas]# echo $?
    0
    

    (3)/home/datas/helloworld.sh目录中的文件是否存在

    [root@KyServer datas]# [ -e helloworld.sh ]
    [root@KyServer datas]# echo $?
    0
    

    (4)多条件判断(&&表示前一条命令执行成功(与),才执行后一条命令,|| 表示上一条命令执行失败后(或),才执行下一条命令)

    [root@KyServer datas]# [ condition ] && echo OK || echo notok
    OK
    [root@KyServer datas]# [ condition ] && [ ] || echo notok
    notok
    

7、流程控制

7.1、if 判断

  1. 基本语法

    if [ 条件判断 ];then
    	程序
    fiif [ 条件判断 ]
    	then
    		程序
    fi
    

    注意事项:

    (1)[ 条件判断式 ],中括号和判断式之间必须有空格

    (2)if 后要有空格

  2. 案例实操

    (1)输入一个数字,如果是1,则输出 dt真帅;如果是2,则输入 dt真牛;如果是其他什么也不输出

    [root@KyServer datas]# vim if.sh
    
    在vim if.sh中写入以下
    #!/bin/bash
    if [ $1 -eq 1 ];then
    	echo "dt真帅"
    elif [ $1 -eq 2 ];then
    	echo "dt真牛"
    fi
    
    [root@KyServer datas]# bash if.sh 1
    dt真帅
    [root@KyServer datas]# bash if.sh 2
    dt真牛
    

7.2、case语句

  1. 基本语法

    case $变量名 in
    "值1")
    	如果变量的值等于值1,则执行程序1
    ;;
    "值2")
    	如果变量的值等于值1,则执行程序2
    ;;
    *)
    	如果变量的值都不是以上的值,则执行此程序
    ;;
    esac
    

    注意事项:

    (1)case行尾必须为单词 “in”,每个模式匹配必须以右括号")"结束

    (2)双分号 “;;” 表示命令序列结束,相对相当于java中的break

    (3)最后的 “*)” 表示默认模式吗,相当于java中的default

  2. 案例实操

    (1)输入一个数字,如果是1,则输入A;如果是2,则输入B;如果是其他,则输入bye

    [root@KyServer datas]# vim case.sh
    
    在 case.sh 中写入以下
    #!/bin/bash
    case $1 in
    1)
    	echo "A"
    ;;
    2)
    	echo "B"
    ;;
    *)
    	echo "bye"
    ;;
    esac
    
    [root@KyServer datas]# bash case.sh 1
    A
    [root@KyServer datas]# bash case.sh 2
    B
    [root@KyServer datas]# bash case.sh 3
    bye
    

7.3、for循环

  1. 基本语法

    • 语法1(连续的值)
    for ((初始值;循环控制条件;变量变化))
     do
     	程序
     done
    
    • 语法2(离散的值)
    for 变量 in 值1 值2 值3
     do
     	程序
     done
    
  2. 案例实操

    (1)从1加到100

    [root@KyServer datas]# cat for1.sh
    
    在 for1.sh 中写入
    for ((s=0,i=1;i<=100;i++))
     do
    	s=$[$s+$i]
     	if [ $i -eq 100 ];then
    		echo $s
    	fi
     done
    
    [root@KyServer datas]# bash for1.sh 
    5050
    

    (2)打印所有输入参数

    [root@KyServer datas]# vim for2.sh
    
    在 for2.sh 中写入
    #!/bin/bash
    for i in $*
     do
    	echo $i
     done
     
    [root@KyServer datas]# bash for2.sh 1 2 3 4 6
    1
    2
    3
    4
    6
    
  3. $* 和 $@ 区别

    [root@KyServer datas]# vim for3.sh
    
    在 for3.sh 写入
    #!/bin/bash
    for i in "$*"
     do
    	echo $i
     done
    
    for i in "$@"
     do
            echo $i
     done
    
    [root@KyServer datas]# bash for3.sh 1 2 3 4 5 6
    1 2 3 4 5 6
    1
    2
    3
    4
    5
    6
    

    区别:$*把所有的参数看成一个整体,而$@把每个参数区别对待

7.4、while循环

  1. 语法

    while [ 条件判断 ]
     do
     	程序
     done
    
  2. 案例实操

    (1)从1加到100

    [root@KyServer datas]# vim while.sh
    
    在 while.sh 中写入
    #!/bin/bash
    s=0
    i=1
    while [ $i -le 100 ]
     do
    	s=$[$s+$i]
    	i=$[$i+1]
     done
    echo $s
    
    [root@KyServer datas]# bash while.sh 
    5050
    

8、read读取控制台输入

  1. 基本语法

    read(选项)(参数)

    选项:

    • -p:指定读取值时的提示符;
    • -t:指定读取值时等待的时间(秒)

    参数:

    • 变量:值读取值的变量名
  2. 案例实操

    (1)提示7秒内,读取控制台输入的名称

    [root@KyServer datas]# vim read.sh
    
    在 read.sh 中写入
    #!/bin/bash
    read -p "请在7s内输入你的名字" -t 7 NAME
    echo $NAME
    
    [root@KyServer datas]# bash read.sh 
    请在7s内输入你的名字dt
    dt
    

9、函数

9.1、系统函数

  1. basename 基本语法

    basename [string / pathname] [suffix] (功能描述:basename 命令会删掉所有的前缀包括最后一个(“/”)字符,然后将字符串显示出来)

    选项:

    suffix 为后缀,如果 suffix 被指定了,basename 会将 pathname 或 string 中的 suffix 去掉

  2. 案例实操

    (1)截取该/home/datas/banzhang.txt 路径的文件名称

    [root@KyServer datas]# basename /home/datas/banzhang.txt 
    banzhang.txt
    [root@KyServer datas]# basename /home/datas/banzhang.txt .txt
    banzhang
    
  3. dirname 基本语法

    dirname 文件绝对路径(功能描述:从给定的包含绝对路径的文件名中去除文件名(非目录的部分),然后返回剩下的路径(目录的部分) )

  4. 案例实操

    (1)获取 banzhang.txt 文件的路径

    [root@KyServer datas]# dirname /home/datas/banzhang.txt 
    /home/datas
    

9.2、自定义函数

  1. 基本语法

    [function] funname[()]
    {
    	Action;
    	[return int;]
    }
    funname
    
  2. 经验技巧

    (1)必须在调用函数地方之前,先声明函数,shell脚本是逐行运行。不会像其他语言一样先编译

    (2)函数返回值,只能通过$?系统变量获得,可以显示加:return 返回,如果不加,将以最后一条命令运行结果,作为返回值。return后跟数值 n(0-255)

  3. 案例实操

    (1)计算两个输入参数的和

    [root@KyServer datas]# vim fun.sh
    
    在 fun.sh 中写入
    #!/bin/bash
    function sum()
    {
    	s=$[$1+$2]
    	echo $s
    }
    
    read -p "请在7s内输入参数1:" -t 7 P1
    read -p "请在7s内输入参数2:" -t 7 P2
    sum $P1 $P2
    
    [root@KyServer datas]# bash fun.sh 
    请在7s内输入参数1:2
    请在7s内输入参数2:4
    6
    

10、shell工具

10.1、cut

cut的工作就是“剪”,具体的说就是在文件中负责剪切数据用的。cut命令从文件的每一行剪切字节、字符和字段将这些字节、字符和字段输出。

  1. 基本用法

    cut[选项参数] filename

    说明:默认分隔符是制表符

  2. 选项参数说明

    选项参数功能
    -f列号,提取第几列
    -d分隔符,按照指定分隔符分割列
  3. 案例实操

    (0)数据准备

    [root@KyServer datas]# vim cut.txt
    dong shen
    guan zhen
    wo wo
    lai lai
    le le
    

    (1)切割 cut.txt 第一列

    [root@KyServer datas]# cut -d " " -f 1 cut.txt 
    dong
    guan
    wo
    lai
    le
    

    (2)切割 cut.txt 第二列、第三列

    [root@KyServer datas]# cut -d " " -f 2,3 cut.txt 
    shen
    zhen
    wo
    lai
    le
    

    (3)在 cut.txt 文件中切割出guan

    # 理解这里
    [root@KyServer datas]# cat cut.txt | grep guan
    guan zhen
    
    # 就会看懂这里
    [root@KyServer datas]# cat cut.txt | grep guan | cut -d " " -f 1
    guan
    

    (4)选取系统PATH变量值,第2个“:”开始后的所有路径

    [root@KyServer datas]# echo $PATH | cut -d ":" -f 3- 
    /usr/local/bin:/usr/sbin:/usr/bin:/root/bin
    

    (5)切割 ifconfig 后打印的IP地址

    [root@KyServer datas]# ifconfig eth0
    eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
            inet 172.24.102.130  netmask 255.255.240.0  broadcast 172.24.111.255
            ether 00:16:3e:16:20:20  txqueuelen 1000  (Ethernet)
            RX packets 2158125  bytes 1833119536 (1.7 GiB)
            RX errors 0  dropped 0  overruns 0  frame 0
            TX packets 1224936  bytes 960553839 (916.0 MiB)
            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
    
    [root@KyServer datas]# ifconfig eth0 | grep "inet"
            inet 172.24.102.130  netmask 255.255.240.0  broadcast 172.24.111.255
    [root@KyServer datas]# ifconfig eth0 | grep "inet"|cut -d " " -f 10
    172.24.102.130
    

    注意事项:inet前面有8个空格所以算9列,inet为第9列

10.2、sed

sed是一种编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为"模式空间",接着用sed命令处理缓冲区中的内容,处理完成后,把缓存区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。

  1. 基本用法

    sed[选项参数] ‘command’ filename

  2. 选项参数说明

    选项参数功能
    -e直接在指令列模式上进行sed的动作编辑
  3. 命令功能描述

    常用命令功能描述
    a新增,a后面可以接字符串,在下一行出现
    d删除
    s查找并替换
  4. 案例实操

    (0) 数据准备

    [root@KyServer datas]# vim sed.txt
    dong shen
    guan zhen
    wo wo
    lai lai
    le le
    

    (1)将"mei vu"这个单词插入到sed.txt第二行下,打印

    [root@KyServer datas]# sed "2a mei nv" sed.txt 
    dong shen
    guan zhen
    mei nv
    wo wo
    lai lai
    le le
    [root@KyServer datas]# cat sed.txt 
    dong shen
    guan zhen
    wo wo
    lai lai
    le le
    

    注意事项:原文件并没有改变

    (2)删除sed.txt文件所有包含wo的行

    [root@KyServer datas]# sed '/wo/d' sed.txt
    dong shen
    guan zhen
    lai lai
    le le
    

    (3)将sed.txt文件中wo替换成ni

    [root@KyServer datas]# sed 's/wo/ni/g' sed.txt
    dong shen
    guan zhen
    ni ni
    lai lai
    le le
    

    注意事项:‘s/wo/ni/g’ 中的g为global,全部替换的意思

    (4)将sed.txt文件中第二行删除并将wo替换为ni

    [root@KyServer datas]# sed -e  '2d' -e 's/wo/ni/g' sed.txt
    dong shen
    ni ni
    lai lai
    le le
    

10.3、awk

一个强大的文本分析工具,把文件逐行地读入,以空格为默认分隔符将每行切片,切开的部分再进行分析处理

  1. 基本用法

    awk[选项参数] ‘pattern1{action1} pattern2{action2}’ filename

    pattern:表示AWK在数据中查找的内容,就是匹配模式

    action:在找到匹配内容时所执行的一系列命令

  2. 选项参数说明

    常用选项参数功能
    -F指定输入文件拆分隔符
    -v赋值一个用户定义变量
  3. 案例实操

    (0)数据准备

    [root@KyServer datas]# sudo cp /etc/passwd ./
    

    (1)搜索passwd文件以root关键字开头的所有行,并输出改行的第7列

    [root@KyServer datas]# awk -F : '/^root/{print $7}' passwd
    /bin/bash
    

    (2)搜索passwd文件以root关键字开头的所有行,并输出该行的第1列和第7列,中间以","号分割

    [root@KyServer datas]# awk -F : '/^root/{print $1","$7}' passwd
    root,/bin/bash
    

    注意:只有匹配了pattern的行才会执行

    (3)只显示/etc/passwd的第一列和第七列,以逗号分割,且在第一行前添加列名"user,shell",在最后一行添加"dt,/bin/zuishaui"

    [root@KyServer datas]# awk -F : 'BEGIN{print "user,shell"} {print $1","$7} END{print "dt,/bin/zuishuai"}' passwd
    user,shell
    root,/bin/bash
    bin,/sbin/nologin
    ...省略...
    apache,/sbin/nologin
    nginx,/sbin/nologin
    dt,/bin/zuishuai
    

    注意:BEGIN在所有数据读取行之前执行;END在所有数据执行之后执行

    (4)将passwd文件中的用户id增加数值1并输出

    [root@KyServer datas]# awk -F : -v i=1  '{print $3+i}' passwd
    1
    2
    3
    4
    ...省略...
    997
    49
    996
    
    或者
    [root@KyServer datas]# awk -F : '{print $3+1}' passwd
    1
    2
    3
    4
    ...省略...
    997
    49
    996
    
  4. awk的内置变量

    变量说明
    FILENAME文件名
    NR已读的记录数(行)
    NF浏览记录的域的个数(切割后,列的个数)
  5. 案例实操

    (1)统计passwd文件名,每行的行号,每行的列数

    [root@KyServer datas]# awk -F : '{print "filename:"FILENAME",linenumber:"NR",columns:"NF}' passwd
    filename:passwd,linenumber:1,columns:7
    ...省略...
    filename:passwd,linenumber:32,columns:7
    

    (2)切割IP

    [root@KyServer datas]# ifconfig eth0 | grep "inet" | awk '{print $2}' passwd
    172.24.102.130
    

    注意事项:awk默认的分隔符为空格和tab。然而,实践中往往需要指定其它符号作为分隔符。

    (3)查询sed.txt中空行所在的行号

    [root@KyServer datas]# vim sed.txt 
    dong shen
    guan zhen
    wo wo
    lai lai
    
    le le
    [root@KyServer datas]# awk '/^$/{print NR}' sed.txt 
    5
    

10.4、sort

sort命令是在Linux里非常有用,它将文件进行排序,并将排序结果标准输出

  1. 基本语法

    sort(选项)(参数)

    选项说明
    -n依照数值的大小排序
    -r以相反的顺序来排序
    -t设置排序时所用的分隔字符
    -k指定需要排序的列
    -o将排序后的结果存入指定的文件

    参数:指定待排序的文件列表

  2. 案例实操

    (0)数据准备

    [root@KyServer datas]# vim sort.sh
    bb:40:5.4
    bd:20:4.2
    xz:50:2.3
    cls:10:3.5
    ss:30:1.6
    

    (1)按照":"分割后的第三列倒序排序

    [root@KyServer datas]# sort -t : -nrk 3 sort.sh 
    bb:40:5.4
    bd:20:4.2
    cls:10:3.5
    xz:50:2.3
    ss:30:1.6
    

11、企业真实面试题

11.1、京东

问题1:使用Linux命令查询file1中空行所在的行号

awk '/^$/{print NR}' file1

问题2:有文件 score.txt 内容如下:

张三 40
李四 50
王五 60

使用Linux命令计算第二列的和并输出

awk -v sum=0 '{sum+=$2} END{print sum}' score.txt

11.2、搜狐&和讯网

问题1:Shell脚本里如何检查一个文件是否存在?如果不存在该如何处理?

#!/bin/bash
if [ -e file ];then
	echo "文件存在"
else
	echo "文件不存在"
fi

11.3、新浪

问题1:用Shell写一个脚本,对文本中无序的一列数字排序

[root@KyServer datas]# cat test.txt 
9
8
3
4
6
5
7
10
1
2
#!/bin/bash
sort -no test.txt test.txt

注意:-o<输出文件> 将排序后的结果存入指定的文件

11.4、金和网络

问题1:请用shell脚本写出查找当前文件夹(/home)下所有的文本文件内容种包含有字符"shen"的文件名称

[root@KyServer datas]# grep -r "shen" /home | cut -d : -f 1
/home/datas/cut.txt
/home/datas/sed.txt
/home/dt/mysite.log

[root@KyServer datas]# grep -r "shen" /home | awk -F : '{print $1}'
/home/datas/cut.txt
/home/datas/sed.txt
/home/dt/mysite.log
  • 2
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值