bash的基础特性[更新中]

2、bash的工作特性之命令执行状态返回值和命令行展开所涉及的内容及其示例演示。
3、请使用命令行展开功能来完成以下练习:
(1)、创建/tmp目录下的:a_c, a_d, b_c, b_d
(2)、创建/tmp/mylinux目录下的:
mylinux/
├── bin
├── boot
│   └── grub
├── dev
├── etc
│   ├── rc.d
│   │   └── init.d
│   └── sysconfig
│   └── network-scripts
├── lib
│   └── modules
├── lib64
├── proc
├── sbin
├── sys
├── tmp
├── usr
│   └── local
│   ├── bin
│   └── sbin
└── var
├── lock
├── log
└── run
5、如何定义一个命令的别名,如何在命令中引用另一个命令的执行结果?
6、显示/var目录下所有以l开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其它字符)的文件或目录。
7、显示/etc目录下,以任意一个数字开头,且以非数字结尾的文件或目录。
8、显示/etc目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录。
9、在/tmp目录下创建以tfile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-22。
10、复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
11、复制/etc目录下所有以.d结尾的文件或目录至/tmp/mytest2目录中。
12、复制/etc/目录下所有以l或m或n开头,以.conf结尾的文件至/tmp/mytest3目录中。

      • bash的基础特性[更新中]
        • 1. 命令状态返回值
        • 2. 命令行展开
        • 3. alias别名
        • 4. glob通配符

1. 命令状态返回值

在bash或其他shell中,命令的执行有两种结果:执行结果状态结果

  • 状态结果
    bash通过状态返回值来输出此结果。

    • 成功:状态结果为0
    • 失败:状态结果为1-255

命令执行完成之后,其状态返回值保存于bash的特殊变量$?中,通过echo $?查看状态结果。

  • 状态结果查看示例
    [root@localhost ~]# ls /home
    test1 test2
    [root@localhost ~]# echo $?
    0
    [root@localhost ~]# lsd /home
    -bash: lsd: command not found
    [root@localhost ~]# echo $?
    127
  • 执行结果
    命令正常执行时,有的还会有命令返回值(命令执行结果),根据命令及其功能不同,结果各不相同。

可以直接引用命令的执行结果作为下一命令的输入:

  • $(COMMAND)
  • `COMMAND` – -> 这里是反引号,不是单引号。
  • 引用命令执行结果示例:
  1. 在/tmp目录下创建以tfile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-22
    • 引用date命令的执行结果,touch /tmp/tfile-$(date +%F-%H-%M-%S)
      [root@localhost tmp]# touch /tmp/tfile-$(date +%F-%H-%M-%S)
      [root@localhost tmp]# ll tfile*
      -rw-r--r--. 1 root root 0 Mar 16 22:37 tfile-2018-03-16-22-37-38
      [root@localhost tmp]# touch /tmp/tfile-$(date +%F-%H-%M-%S)
      [root@localhost tmp]# ll tfile*
      -rw-r--r--. 1 root root 0 Mar 16 22:37 tfile-2018-03-16-22-37-38
      -rw-r--r--. 1 root root 0 Mar 16 22:37 tfile-2018-03-16-22-37-45

2. 命令行展开

  • ~:自动展开为用户的家目录,或指定的用户的家目录
  • {}:可承载一个以逗号分隔的路径列表,或以..连接的一个序号范围内的路径列表,并能够将其展开为多个路径;
    例如:/tmp/{a,b}相当于/tmp/a /tmp/b,/tmp/a{1..9}相当于/tmp/a1,/tmp/a2…到/tmp/a9。
  • 命令行展开的用法示例
    1. 创建/tmp目录下的:a_c, a_d, b_c, b_d
      • touch /tmp/{a,b}_{c,d}
        [root@localhost tmp]# touch /tmp/{a,b}_{c,d}
        [root@localhost tmp]# ls
        a_c a_d b_c b_d
    2. 创建/tmp/mylinux目录下的如下树结构
      ├── bin
      ├── boot
      │ └── grub
      ├── dev
      ├── etc
      │ ├── rc.d
      │ │ └── init.d
      │ └── sysconfig
      │ └── network-scripts
      ├── lib
      │ └── modules
      ├── lib64
      ├── proc
      ├── sbin
      ├── sys
      ├── tmp
      ├── usr
      │ └── local
      │ ├── bin
      │ └── sbin
      └── var
      ├── lock
      ├── log
      └── run

      • mkdir -pv /tmp/mylinux/bin/{boot/grub,dev,etc/{rc.d/init.d,sysconfig/network.scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,run}}
        [root@localhost tmp]# tree /tmp/mylinux
        /tmp/mylinux
        └── bin
        ├── boot
        │ └── grub
        ├── dev
        ├── etc
        │ ├── rc.d
        │ │ └── init.d
        │ └── sysconfig
        │ └── network.scripts
        ├── lib
        │ └── modules
        ├── lib64
        ├── proc
        ├── sbin
        ├── sys
        ├── tmp
        ├── usr
        │ └── local
        │ ├── bin
        │ └── sbin
        └── var
        ├── lock
        ├── log
        └── run
        24 directories, 0 files
    3. 在/tmp/test/目录下创建9个文件,文件名为file1到file9
      • touch /tmp/test/file{1..9}
        [root@localhost tmp]# touch /tmp/test/file{1..9}
        [root@localhost tmp]# ls test
        file1 file2 file3 file4 file5 file6 file7 file8 file9

3. alias别名

alias是命令的别称,用户可以定义alias来快速使用某命令行,其作用就是可以简写命令

  • 查看别名
    可以使用命令alias获取所有可用别名的定义。

    • alias
      [root@localhost tmp]# alias
      alias cp='cp -i'
      alias egrep='egrep --color=auto'
      alias fgrep='fgrep --color=auto'
      alias grep='grep --color=auto'
      alias l.='ls -d .* --color=auto'
      alias ll='ls -l --color=auto'
      alias ls='ls --color=auto'
      alias mv='mv -i'
      alias rm='rm -i'
      alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
  • 定义或修改别名
    • alias NAME=’COMMAND’ ,只对当前shell进程有效。
    • 如创建一个名为mkdirs的alias,alias mkdirs=’mkdir -pv dir1/dir2/dir3{a..d}’
      [root@localhost tmp]# alias mkdirs='mkdir -pv dir1/dir2/dir3{a..d}'
      [root@localhost tmp]# mkdirs
      mkdir: created directory ‘dir1’
      mkdir: created directory ‘dir1/dir2’
      mkdir: created directory ‘dir1/dir2/dir3a’
      mkdir: created directory ‘dir1/dir2/dir3b’
      mkdir: created directory ‘dir1/dir2/dir3c’
      mkdir: created directory ‘dir1/dir2/dir3d’
      [root@localhost tmp]# tree dir1
      dir1
      └── dir2
      ├── dir3a
      ├── dir3b
      ├── dir3c
      └── dir3d
    • 修改~/.bashrc文件(用户家目录下),对当前用户永久有效,
      在文件末尾添加定义的别名alias NAME='COMMAND'
      修改后下次登录生效,或执行source ~/.bashrc立即生效。
      这里不再做演示。

4. glob通配符

Linux使用过程中,查找所需的文件是非常普遍的操作。Shell提供了一套字符串匹配规则,使用元字符匹配检索内容,伊阿斑用于检索文件名。当Shell遇到元字符时,会把它们当作特殊字符进行特殊处理,而非普通字符的处理方式,这些元字符是globbing(通配符)

通配符是对整体文件名进行匹配,而非部分,并且不区分大小写

  • 通配符匹配模式

*:匹配任意长度的任意字符
?:匹配任意单个字符
[]:匹配指定范围内的任意单个字符

如:[a-z],[A-Z],[0-9],[a-z0-9]

[!]:匹配指定范围外的任意单个字符

[!]和正则表达式中的[^]作用相同

  • 正则表达式
    正则表达式是一个字符匹配标准,不同于通配符的常用于文件名匹配和Shell解析,正则表达式更多用来匹配文件内容,并需要工具的支持,如sed、grep、awk等。
  • 正则表达式的匹配模式
    • 字符匹配
      .:匹配任意单个字符
      *:匹配其前面一个字符出现任意次
      ?:匹配其前面的字符1次或0次
      +:匹配其前面一个字符出现至少一次(在扩展正则表达式中)
    • 位置匹配
      ^:锚定行首
      $:锚定行尾
      \<或\b:锚定词首,其后面的任意字符必须作为单词首部出现
      \>或\b:锚定词尾,其前面的任意字符必须作为单词尾部出现
      \B:非单词的开头或结尾
      ^$:空白行
    • 分组
      (ab)* : 匹配ab这个分组出现任意次
      \1:引用第一个左括号以及与之对应的右括号所包括的所有内容,同理还有\2,\3
    • 特殊子字符类
      [:alnum:] :任何字母和数字
      [:alpha:] :任何字母
      [:cntrl:] :控制字符. 在ASCII表中对应八进制000 到 037, 和177 (‘DEL’).
      [:digit:] :任何数字
      [:graph:] :匹配打印字符,相当于’[:alnum:]’ +’[:punct:]’.
      [:lower:] :小写字母
      [:print:] :可打印字符,相当于 ‘[:alnum:]’, ‘[:punct:]’, 和space.
      [:punct:] 标点符号,’! ” # $ % & ’ ( ) * + , – . / : ; < = > ? @ [ \ ] ^ _ ’ { | } ~’
      [:space:] 空白字符,tab, newline, vertical tab, form feed, carriage return, and space.
      [:upper:] 大写字母
      [:xdigit:] 任何16进制的数字,相当于[0-9a-fA-F]
  • 通配符配合正则表达式的特殊子字符来使用
    • 通配符[]
      [[:upper:]]:所有大写字母
      [[:lower:]]:所有小写字母
      [[:alpha:]]:所有字母
      [[:digit:]]:所有数字
      [[:alnum:]]:所有字母和数字
      [[:space:]]:所有空白字符
      [[:punct:]]:所有标点符号
    • 通配符[^]
      如:[^[:upper:]]:除大写字母外的单个字符,
      其他子字符用法相同,不作一一列举。
  • 通配符使用示例
    1. 显示/tmp目录下,以任意一位数字开头,且以非数字结尾的文件或目录
      • ls -d /tmp/[0-9]*[^0-9]
        [root@localhost tmp]# ls -d /tmp/*
        /tmp/1_a /tmp/1dir /tmp/3_b /tmp/5_b /tmp/h_7 /tmp/i_7 /tmp/j_7
        /tmp/1_b /tmp/2dir /tmp/3_c /tmp/5_c /tmp/h_8 /tmp/i_8 /tmp/j_8
        /tmp/1_c /tmp/3_a /tmp/5_a /tmp/h_6 /tmp/i_6 /tmp/j_6
        [root@localhost tmp]# ls -d /tmp/[0-9]*[^0-9]
        /tmp/1_a /tmp/1_c /tmp/2dir /tmp/3_b /tmp/5_a /tmp/5_c
        /tmp/1_b /tmp/1dir /tmp/3_a /tmp/3_c /tmp/5_b
    2. 显示/tmp/目录下,以非字母开头后面跟一个字母及其他任意长度任意字符的文件或目录
      • ls -d /tmp/[^a-z][a-z]*
        [root@localhost tmp]# ls -d /tmp/[^a-z][a-z]*
        /tmp/1dir /tmp/2dir
    3. 复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
      • cp -r /etc/p*[^0-9] /tmp/mytest1
        [root@localhost mytest1]# cp -r /etc/p*[^0-9] /tmp/mytest1
        [root@localhost mytest1]# ls
        pam.d pcp.conf pear.conf pki postfix profile python
        passwd pcp.env php.d plymouth ppp profile.d
        passwd- pcp.sh php.ini pm prelink.conf.d protocols
        pcp pear pinforc popt.d printcap pulse
    4. 显示/var目录下所有以l开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其它字符)的文件或目录。
      • ls -d /var/l?*[[:lower:]]
        [root@localhost ~]# ls -d /var/l?*[[:lower:]]
        /var/lib /var/local /var/lock /var/log
    5. 显示/tmp目录下,以任意一个数字开头,且以非数字结尾的文件或目录。
      • ls -d /tmp/[0-9]*[^0-9]
        [root@localhost ~]# ls -d /tmp/[0-9]*[^0-9]
        /tmp/1_a /tmp/1_c /tmp/2dir /tmp/3_b /tmp/5_a /tmp/5_c
        /tmp/1_b /tmp/1dir /tmp/3_a /tmp/3_c /tmp/5_b
    6. 显示/tmp目录下,以非字母开头,后面跟了一个字母以及其它任意长度任意字符的文件或目录。
      • ls -d /tmp/[^a-z][a-z]*
        [root@localhost ~]# ls -d /tmp/[^a-z][a-z]*
        /tmp/1dir /tmp/2dir
    7. 复制/etc目录下所有以.d结尾的文件或目录至/tmp/mytest2目录中。
      • cp -r /etc/*.d /tmp/mytest2
        [root@localhost mytest2]# cp -r /etc/*.d /tmp/mytest2
        [root@localhost mytest2]# ls
        auto.master.d init.d profile.d rwtab.d
        bash_completion.d latrace.d rc0.d setuptool.d
        binfmt.d ld.so.conf.d rc1.d slp.reg.d
        cgconfig.d logrotate.d rc2.d statetab.d
        chkconfig.d modprobe.d rc3.d sudoers.d
        cron.d modules-load.d rc4.d sysctl.d
        depmod.d my.cnf.d rc5.d tmpfiles.d
        dnsmasq.d oddjobd.conf.d rc6.d usb_modeswitch.d
        dracut.conf.d pam.d rc.d xinetd.d
        exports.d php.d reader.conf.d yum.repos.d
        gdbinit.d popt.d request-key.d
        grub.d prelink.conf.d rsyslog.d
    8. 复制/etc/目录下所有以l或m或n开头,以.conf结尾的文件至/tmp/mytest3目录中。
      • cp /etc/[l,m,n]*.conf /tmp/mytest3
        [root@localhost mytest3]# cp /etc/[l,m,n]*.conf /tmp/mytest3
        [root@localhost mytest3]# ls
        ld.so.conf locale.conf mke2fs.conf ntp.conf
        libaudit.conf logrotate.conf nfsmount.conf numad.conf
        libuser.conf man_db.conf nsswitch.conf

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/92597

(0)
GeniusyqcGeniusyqc
上一篇 2018-03-17 21:06
下一篇 2018-03-18

相关推荐

  • 2017中华数据库与运维大会强势回归!

         时隔一年,2017年中华数据库与运维大会将于06月03日在上海宝丰联大酒店强势回归,届时来自全国各行各业的IT从业人员将欢聚上海,探讨与交流数据库和运维的经验。       自2009年以来,超过4000位技术总监、技术负责人、架构师、项目经理、运维总监、运维经理、DBA经理、DBA、运维…

    2017-02-28
  • 管理磁盘分区之fdisk详解

    Mozatr的不定期更新,处于学习阶段的Mozart,愿不断分享,不断进步。 此次分享一个重要的管理分区命令:fdisk ,我们一一阐述。 (一)分区 首先我们了解下什么是分区,分区是将一个硬盘驱动器分成若干个逻辑驱动器,分区是把硬盘连续的区块当做一个独立的磁盘使用。分区表是一个硬盘分区的索引,分区的信息都会写进分区表。 分区的优点:  &nbsp…

    Linux干货 2017-08-19
  • Linux启动和内核管理

                                        Linux启动和内核管理 本章内容: centos5和centos6的启动流程 服务管理 grub…

    系统运维 2016-09-21
  • shell脚本编程进阶

    一些常用的编程语句,

    2017-12-23
  • Nginx反向代理的常用调度算法

    upstream 调度算法 1.rr 按客户端请求顺序把客户端的请求逐一分配到不同的后端的服务器,这相当于lvs中的rr算法。如果后端服务器岩机(默认情况下只检测80端口,如果后端报502,404,403,503,还是会直接返给用户),岩机服务器会被自动剔除,使用户访问不受影响,请求会分配给正常的服务器 2.weight(权重) 在轮询算法的基础上加上权重(…

    Linux干货 2016-06-01
  • 马哥教育网络班22期第4周课程作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@MyCloudServer ~]# cp /etc/skel/ /home/tuser1  [root@MyCloudServer ~]# c…

    Linux干货 2016-09-19