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

相关推荐

  • Linux系统下的bonding设置

    bonding多个物理网卡聚合成一个虚拟网卡     Bonding,其原理是讲多个物理网卡聚合成一个虚拟网卡,一张网卡正常工作,其余网卡作为备用,每隔一段时间(miimon=毫秒),向正常工作的网卡发一状态询问,若没回复,则认为其运行失败,然后就会启用备用网卡,但是IP地址不会改变。   &nbs…

    Linux干货 2016-09-07
  • 五大主流数据库模型

    导读:无论是关系型数据库还是非关系型数据库,都是某种数据模型的实现。本文将为大家简要介绍5种常见的数据模型,让我们来追本溯源,窥探现在流行的数据库解决方案背后的神秘世界。 什么是数据模型? 访问数据库中的数据取决于数据库实现的数据模型。数据模型会影响客户端通过API对数据的操作。不同的数据模型可能会提供或多或少的功能。一般而言,数据模型不会直接提供过多的功能…

    Linux干货 2015-04-04
  • N26第四周博客作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限cp -r /etc/skel /home/tuser1chmod -R go= /home/tuser1 2、编辑/etc/group文件,添加组hadoop。echo “hadoop:x:2020:”…

    Linux干货 2017-02-27
  • Java中的CopyOnWrite容器

    Copy-On-Write简称COW,是一种用于程序设计中的优化策略。其基本思路是,从一开始大家都在共享同一个内容,当某个人想要修改这个内容的时候,才会真正把内容Copy出去形成一个新的内容然后再改,这是一种延时懒惰策略。从JDK1.5开始Java并发包里提供了两个使用CopyOnWrite机制实现的并发容器,它们是CopyOnWriteArrayList和…

    Linux干货 2016-08-15
  • N26-博客作业-week10

    1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情) 2、为运行于虚拟机上的CentOS 6添加一块新硬件,提供两个主分区;  (1) 为硬盘新建两个主分区;并为其安装grub;  (2) 为硬盘的第一个主分区提供内核和ramdisk文件; 为第二个分区提供rootfs;  (3) 为rootfs提供bas…

    2017-04-09
  • CentOS通过bind配置DNS服务器

    一、创建DNS主服务器 1、安装bind并配置主配置文件     主服务器为CentOS 7,主服务地址为172.16.11.55     安装bind [root@xinfeng ~]# yum install bind  &n…

    Linux干货 2016-04-18