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

相关推荐

  • 运维面试题, 不知是否正确的答案

    1、简述TCP三次握手四次挥手过程及各过程中客户端和服务器端的状态。 握手: client 发送请求SYN到 server; 状态:server;初始状态为LISTEN,client 发送SYN后变为SYN_SENT server 发送ACK回应,并发送SYN请求到 client;状态:服务器收到SYN后,变为SYN_RCVD,发送ACK+SYN后,变为ES…

    Linux干货 2016-06-23
  • IO,用户与组管理,文件,目录权限管理

           文件统配匹配模式:元字符文件名通配符*匹配任意长度的任意字符[root@localhost ~]# ls /root/D*/root/Desktop  /root/Documents  /root/Downloads ?匹配单个任意字符[root@localhost ~]# …

    Linux干货 2016-08-05
  • class9 bash编程基础(一)

    一、编程基础 程序:指令+ 数据 程序编程风格: 过程式:以指令为中心,数据服务于指令 对象式:以数据为中心,指令服务于数据 shell 程序:提供了编程能力,解释执行 程序的执行方式 计算机:运行二进制指令; 编程语言: 低级:汇编 高级: 编译:高级语言–> 编译器–> 目标代码   &n…

    Linux干货 2016-08-15
  • iptables练习

    系统的INPUT和OUTPUT默认策略为DROP; 1、限制本地主机的web服务器在周一不允许访问;新请求的速率不能超过100个每秒;web服务器包含了admin字符串的页面不允许访问;web服务器仅允许响应报文离开本机; 系统默认策略设定: ~]# iptables -P INPUT DROP ~]# iptables -P OUPUT DROP 网络说明…

    Linux干货 2016-12-27
  • 20本最好的Linux免费书籍

    前些天Neo推荐了一个网站有《超过100本的linux免费书籍》,这里,我也向大家推荐20本最好的Linux免费书籍,当然,也是英文版的。 1. Ubuntu Pocket Guide and Reference 一本介绍关于Ubuntu 8.04和8.10的使用书。 Website www.ubuntupocketguide.com Author Keir…

    Linux干货 2015-04-01
  • smb

    练习: 创建一个共享ftp,路径为/var/ftp/pub;要求仅centos和gentoo用户能上传;此路径对其它用户不可见; [root@node1 ~]# yum -y install samba [root@node1 ~]# vim /etc/samba/smb.con…

    Linux干货 2016-10-23