2、文件通配符,文件创建、复制等操作

1:bash特性之状态返回值

变量$?,用于保存命令执行成功与否的状态,0表示成功,1-255表示失败,以命令ls为例:

  • 执行成功

[root@localhost ~]# ls /usr/    
bin  etc  games  include  lib  lib64  libexec  local  sbin  share  src  tmp 
[root@localhost ~]# echo $? 
0

  • 命令输入错误

[root@localhost ~]# lss /usr 
-bash: lss: command not found 
[root@localhost ~]# echo $? 
127

  • 命令参数输入错误

[root@localhost ~]# ls /usrrr 
ls: cannot access /usrrr: No such file or directory 
[root@localhost ~]# echo $? 
2

其他错误状态,$?也会是非0结果。

2:命令行展开

2.1:使用命令行展开,创建/tmp下的a\_c,a\_d,b\_c,b\_d文件。

[root@localhost ~]# mkdir -pv {a,b}_{c,d} 
mkdir: created directory `a_c' 
mkdir: created directory `a_d' 
mkdir: created directory `b_c' 
mkdir: created directory `b_d' 
[root@localhost ~]# ls -d {a,b}_{c,d} 
a_c  a_d  b_c  b_d

2.2:在/tmp下创建如下文件。

这里写图片描述

[root@localhost ~]# mkdir -pv /tmp/mylinux/{bin,boot/grub,etc{/rc.d/init.d,/sysconfig/network-scripts},dev,lib/modules,lib64,proc,sbin,sys,tmp,usr/local{/bin,/sbin},var{/lock,/log,/run}}
[root@localhost ~]# 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
    `-- run24 directories, 0 files

3:如何定义一个命令的别名?如何在一个命令中引用另一个命令的结果?

使用反引“或$()可引用其他命令的执行结果:

  • 使用反引号

[root@localhost ~]# dirname `which touch`
/bin

# 显示命令touch所在的路径名

  • 使用$()

[root@localhost ~]# dirname $(which touch)
/bin

4:显示/var目录下所有以字母“l”开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其他字符)的文件和目录

[root@localhost ~]# ls -d /var/l*[[:digit:]]*[[:lower:]]
/var/l13u  /var/lfs3k

5:显示/etc目录下以任意一个数字开头且以一个非数字结尾的文件和目录

[root@localhost ~]# ls -d /etc/[[:digit:]]*[^[:digit:]]
/etc/222kkk  /etc/333uuu

6:显示/etc目录下以非字母开头且后面跟了一个字母和其他任意长度任意字符的文件和目录

[root@localhost ~]# ls -d /etc/[^[:alpha:]][[:alpha:]]*
/etc/1djj

7:在/tmp下创建以tfile开头,后跟当前时间的文件

[root@localhost ~]# touch /tmp/tfile-`date +%F-%H-%M-%S`
[root@localhost ~]# touch /tmp/tfile-`date +%F-%H-%M-%S`
[root@localhost ~]# ls /tmp
tfile-2016-08-25-08-14-35  tfile-2016-08-25-08-14-36

8:复制/etc目录下以字母“p”开头,以非数字结尾的文件到/tmp/mytest1目录中

[root@localhost ~]# mkdir /tmp/mytest1
[root@localhost ~]# cp -r /etc/p*[^[:digit:]] /tmp/mytest1/
[root@localhost ~]# ls /tmp/mytest1/
pam.d  passwd  passwd-  pki  plymouth  pm  popt.d  postfix  ppp  prelink.conf.d  printcap  profile  profile.d  protocols

9:复制/etc目录下所有以.d结尾的目录和文件至/tmp/mytest2目录中

[root@localhost ~]# mkdir /tmp/mytest2
[root@localhost ~]# cp -r /etc/*.d /tmp/mytest2
[root@localhost ~]# ls /tmp/mytest2
bash_completion.d  dracut.conf.d  makedev.d   prelink.conf.d  rc1.d  rc5.d      statetab.d  yum.repos.d
chkconfig.d        init.d         modprobe.d  profile.d       rc2.d  rc6.d      sudoers.d
cron.d             ld.so.conf.d   pam.d       rc.d            rc3.d  rsyslog.d  sysctl.d
depmod.d           logrotate.d    popt.d      rc0.d           rc4.d  rwtab.d    xinetd.d

10:复制/etc目录下所有以字母l或n或m开头,以.conf结尾的文件至目录/tmp/mytest3中

[root@localhost ~]# mkdir /tmp/mytest3
[root@localhost ~]# cp -r /etc/[lmn]*.conf /tmp/mytest3
[root@localhost ~]# ls /tmp/mytest3
ld.so.conf  libaudit.conf  libuser.conf  logrotate.conf  mke2fs.conf  nsswitch.conf

原创文章,作者:wangzhenyu177,如若转载,请注明出处:http://www.178linux.com/47152

(0)
wangzhenyu177wangzhenyu177
上一篇 2016-09-19
下一篇 2016-09-19

相关推荐

  • 位置变量在Shell脚本编程中的作用

    位置变量:         如果要向一个shell脚本传递信息,可以使用位置参数完成此功能;参数相关数目传入脚本,此数目可以任意多,但只有前9个可以被访问,使用shift命令可以改变这个限制;参数从第一个开始,在第九个结束;每个访问参数前要加$符号;第一个参数为0,表示预留保存实…

    Linux干货 2016-08-15
  • haproxy负载均衡两个后端httpd和mysql

    前端主机:172.16.71.1,后端主机:172.16.71.4和172.16.71.5 前端主机安装haproxy yum install haproxyvim /etc/haproxy/haproxy.cfgglobal    log         127.0.0.1 local2 &nbs…

    Linux干货 2017-02-12
  • 马哥教育网络班20期+第3周课程练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@localhost ~]# who | cut -d" " -f1 | sort -u 2、取出最后登录到当前系统的用户的相关信息。 […

    Linux干货 2016-06-26
  • PXE网络引导系统自动化安装CentOS7

     一.PXE 注意:安装前 selinux 禁用,iptables 关闭 dhcp 服务器静态IP地址  1.PXE的工作原理:      Client向PXE Server上的DHCP发送IP地址请求消息,DHCP检测Client是否合法(主要是检测Client的网卡MAC  &nbsp…

    Linux干货 2017-07-24
  • 高级文件系统管理(swap,RAID,LVM)

    交换分区wasp swap文件系统:     linux上的交换分区必须使用独立的文件系统;         其文件系统的system ID必须为82 创建swap设备,文件系统,使用mkswap命令 创建步骤:   &…

    Linux干货 2016-08-30
  • haproxy代理服务

    HAProxy: LB Cluster:         四层:   lvs, nginx(stream),haproxy(mode tcp)         七层:   http: nginx(http, ngx_http_upstrea…

    Linux干货 2017-05-17