Bash shell

一、认识bash shell

1、登录取得的shell就记录在/etc/passwd这个文件内

  可以使用cat /etc/passwd查看

2、bash shell 功能

  a. 命令记忆能力(history),默认1000个,存在~/.bash_history文件

  b. 命令与文件补全功能(Tab键的好处)

    【Tab】接在一串命令的第一个字的后面,则为命令补全

    【Tab】接在一串命令的第二个字以后时,则为文件补齐。

  c. 命令别名设置功能(alias), alias lm='ls -al'

  d. 作业控制、前台、后台控制

  e. 程序脚本(shell script)

  f.  通配符(Wildcard)

 

3、bash shell 的内置命令: type

  语法:type [-tpa] name

  参数:

   type: 不加任何参数时, type会显示name是外部命令还是bash内置命令

   -t:   当加入-t 参数时, type会将name以下面这些字眼显示出它的意义:

      file:表示为外部命令;

      alias: 表示该命令为命令别名所设置的名称

      builtin : 表示该命令为bash内置的命令功能

   -p:  如果后面接的name为外部命令时, 才会显示完整文件名

   -a :会由PATH变量定义的路径中,将所有含name的命令都列出来,包含alias

  type主要在找出“执行文件”而不是一般文件名。所以,这个type也可以用来作为类似which命令的用途

 

二、shell 的变量功能  

  1、变量的显示与设置: echo, unset

    变量的显示: echo ---》 echo $variable 或 echo ${varible}

    变量的设置规则:

      a. 变量与变量内容以一个等号“=”来连接,如下所示: myname=sam

      b. 等号两边不能直接接空格符

      c. 变量名称只能是英文字母与数字,但是开头字符不能是数字

      d. 变量内容若有空格符可使用双引号" 或单引号 ' 将变量内容结合起来,但是双引号内的特殊字符如$等,可以保留原本的特性,单引号内的特殊字符则仅为一般字符(纯文本)

      e.可用转义字符“\”将特殊符号变成一般字符

      f. 在一串命令中,还需要通过其他的命令提供的信息,可以使用反单引号。`命令` 或 $(命令),

        特别注意,那个是键盘上方数字键1左边那个按键,而不是单引号。

      g. 若该变量为了增加变量内容时, 则可用$变量名称或¥{变量}累加内容,如下:  

        PATH=$PATH:/home/bin

      h. 若该变量需要在其他子进程执行,则需要以export来使变量变成环境变量:

        "export PATH"

      i. 通常大写字符为系统默认变量,自行设置变量可以使用小写字符, 方便判断

        j.取消变量: unset 变量名称

    子进程: 就是说在我目前这个shell的情况下,去打开另一个新的shell,新的那个shell就是子进程。在一般的状态下,父进程的自定义变量是无法再子进程内使用的。但是通过export将变量变成环境变量后,就能够在子进程下面应用了。

 

  2、 环境变量的功能

    查看环境量: env

    常见的环境变量:

      HOME: 代表用户的主文件夹。

      SHELL: 它告知我们目前这个环境使用的shell是哪个程序?Linux默认使用/bin/bash的

      HISTSIZE: 这个与“历史命令”有关,即是我们曾经执行过的命令可以被系统记录下来,而记录的“条数”则是由这个值来设置的。

      MAIL:当我们使用mail这个命令在收信时系统会去读取的邮件信箱文件

      PATH: 就是执行文件查找的路径,目录 与目录中间以冒号(:)分隔,由于文件的查找是依序由PATH的变量内的目录来查询,所以目录的顺序也是重要的。

      LANG:语系数据

      RANDOM: 这是“随机数”的变量。在BASH的环境下,这个RANDOM变量的内容介于0~32767

 

    set查看所有变量(含有环境变量与自定义变量)

     a. PS1(提示符的设置):

      这是PS1(数字的1, 不是英文字母),这个东西就是我们的“命令提示符”。当我们每次按下【Enter】键去执行某个命令后,最后要在次出现提示符时, 就会主动去读取这个变量值了。上面PS1内显示的是一些特殊符号,这些特殊符号可以显示不同的信息,每个distributions的bash默认的PS1变量内容可能有些区别,你可以用man bash 查询一下PS1的相关说明,以理解下面的一些符号意义。

    \d: 可显示出“星期月日”的日期格式, 如“Mon Feb 2”

    \H: 完整的主机名, 如“www.vbird.tsai”

    \h: 仅去主机名在第一个小数点之前的名字, 如“www”

    \t: 显示时间,为24小时格式的“HH:MM:SS”

    \T: 显示时间, 为12小时格式的“HH:MM:SS”

    \A: 显示时间,为24小时格式的“HH:MM”

    \@:显示时间, 为12小时格式的“am/pm”样式

    \u: 目前用户的账号名称,如“root”

      \v: BASH的版本信息

    \w: 利用basename函数取得工作目录名称,所以仅会列出最后一个目录名

    \#: 执行的第几个命令

    \$: 提示符,如果是root时,提示符为#, 否则就是$

    例: PS1='[\u@\h \w \A #\#]\$ ' --------》 [root@www /home/dmtsai 16:40 #12]#

 

    b.$(关于本shell的PID)

      “$”本身也是个变量。这个代表的是目前这个Shell的线程号,即是所谓的PID(Process ID)

    c. ? (关于上个执行命令的回传码)

      这个变量是上一个执行命令所传回的值, 当我们执行某些命令时, 这些命令都会回传一个执行后的代码。一般来说, 如果成功执行该命令,则会回传一个0值。如果发生错误,则回传一个非0值。

    d. OSTYPE, HOSTTYPE, MACHTYPE(主机硬件与内核的等级)

  

    export: 自定义变量转成环境变量

      export 变量名称

3、影响显示结果的语系变量(locale)

 

4、变量键盘读取、数组与声明: read, array, declare

  a. read : 读取来自键盘输入的变量

    read 【-pt】 variable

    -p: 后面可以接提示符

    -t: 后面可以接等待的“秒数”

  b. declare/typeset

    declare或typeset是一样的功能,就是声明变量的类型。

    declare [-aixr] variable

     参数:

      -a: 将后面名为variable的变量定义成为数组(array)类型

      -i: 将后面名为variable的变量定义为整数数字(integer)类型

        -x: 用法与export一样,就是将后面的variable变成环境变量, 注意将-变成+可以进行“取消”操作,将环境变量变成一般变量

      -r: 将变量设置成为readonly类型,该变量不可被更改内容,也不能重设

 

    由于在默认的情况下面, bash对于变量有几个基本的定义:

      a. 变量类型默认为“字符串”, 所以若不指定变量类型, 则1+2为一个“字符串”而不是“计算式”,

      b. bash环境中的数值计算, 默认最多仅能到达整数类型,所以1/3结果是0

 

    数组(arry)变量类型

      var[index]=content

      读取: ${var[index]}

 

5、与文件系统及程序的限制关系: ulimit

   bash可以限制用户的某些系统资源的,包括可以打开的文件数量、可以使用的CPU时间、可以使用的内存总量等

    ulimit [-SHacdfltu] [配额]

    参数: 

      -H: hard limit 严格的设置,必定不能超过这个设置的数值

      -S: soft limit 警告的设置,可以超过这个设置值,但是若超过则有警告信息

      -a: 后面不接任何参数,可列出所有的限制额度

      -c: 当某些进程发生错误时,系统可能会将该进程在内存中的信息写成文件(排错用), 这种文件就被称为内核文件。此为限制每个内核文件的最大容量。

      -f: 此shell可以创建的最大文件容量(一般可能设置为2GB)单位为KB

      -d: 进程可使用的最大断裂内存(segment)容量

      -l: 可用于锁定(lock)的内存量。

      -t: 可使用的最大CPU时间(单位为秒)

      -u: 单以用户可以使用的最大进程数量。

 

    注意: 想要复原ulimit的设置最简单的方法就是注销再登陆,否则就是得要重新以ulimit设置才行。不过要注意的是一般身份用户如果以ulimit设置了-f的文件大小,那么他只能继续减少文件的容量,不能增加文件的容量。

 

6、变量内容的删除、替代与替换

   变量内容的删除与替换

    

变量设置方式 说明
${变量#关键字} 若变量内容从头开始的数据符合“关键字”, 则将符合的最短数据删除
${变量##关键字} 若变量内容从头开始的数据符合“关键字”, 则将符合的最长数据删除
${变量%关键字} 若变量内容从尾向前的数据符合“关键字”,则将符合的最短数据删除
${变量%%关键字} 若变量内容从尾向前的数据符合“关键字”, 则将符合的最长数据删除
${变量/旧字符串/新字符串} 若变量内容符合“旧字符串”, 则第一个旧字符串被新字符串替换
${变量//旧字符串、新字符串} 若变量内容符合“旧字符串”, 则全部旧字符串被新字符串替换

   变量的测试与内容替换

     在某些时刻我们经常需要“判断”某个变量是某存在,若变量存在则使用既有的设置,若变量不存在则给予一个常用的设置。

      new_var=${old_var-content}

      new_var: 新的变量,主要用来替换旧变量。新旧变量名称其实经常是一样的

      old_var: 旧的变量, 被测试的选项

      content: 变量的“内容”

     注: new_var=${old_var:-content}

        加上:后若变量内容为空或者为未设置,度能够以后面的内容替换

      如果想要将旧变量内容也一起替换掉的话,那么就是用等号(=):

        如: unset str; var=${str=newvar} --->var=newvar, str=newvar

           str="oldvar"; var=${str=newvar}--->var=newvar, str=oldvar

       如果只想知道,如果旧变量不存在时, 整个测试就告知我“有错误”,此时就能够使用问号“?”

       如: var=${str?无此变量}

 

三、命令别名与历史命令

    1、命令别名设置:alias, unalias

      例: alias rm='rm -i'

        alias 列出所有命令别名

        unalias rm 解除命令别名

    2、历史命令:history

        history [n]

        history [-c]

        history [-raw] histfiles

      参数:

        n: 数字,是要列出最近的n条命令行的意思

        -c: 将目前的shell中的所有history内容全部消除。

        -a: 将目前新增的history命令新增入histfiles中, 若没有加histfiles,默认写入~/.bash_history

        -r: 将histfiles的内容读到目前这个shell的history记忆中

        -w: 将目前的history记忆内容写入histfiles中

       有关history的命令:

        !number :执行第几条命令

        !command : 由最近的命令向前搜寻命令串开头为command的那个命令,并执行

        !! : 就是执行上一个命令(相当于按up键后,按enter键)

 

四、Bash Shell的操作环境

   1、路径与命令查找顺序

     基本上,命令运行的顺序可以这样看:

     1、以相对/绝对路径执行命令,例如: "/bin/ls"或“./ls”

     2、由alias找到该命令来执行

     3、由bash内置的(builtin)命令来执行

     4、通过$PATH这个变量的顺序找到的第一个命令来执行

   可以通过type -a command 查看执行顺序

  2、bash的登录与欢迎信息:/etc/issue, /etc/motd

    a. 终端机接口(tty1~tty6)登录时的登录界面: /etc/issue登录界面提示符设置文件

      

 

  issue内的各个代码意义
\d 本地端时间的日期
\l 显示第几个终端机接口
\m 显示硬件的等级(i386/i486/i586/i686...)
\n 显示主机的网络名称
\o 显示domain name
\r 操作系统的版本(相当于rname -r)
\t 显示本地端的时间
\s 操作系统的名称
\v 操作系统的版本

       如果你想要让用户登录后取得一些信息,例如你想要让大家都知道的信息,那么可以将信息加入/etc/motd里面去:如下

      

  3、bash的环境配置文件

    (1)、 login与non-login shell

      login shell:取得bash完整的登录流程中,就称为login shell.

      non-login shell: 

      

      login shell 只会读取这两个配置文件:

        /etc/profile:这是系统整体的设置,最好不要修改此配置文件

        ~/.bash_profile或~/.bash_login或~/.profile: 属于用户个人设置

      /etc/profile(login shell才会读):

        这个文件设置的变量主要有:

          PATH:会依据UID决定PATH变量要不要含有sbin的系统命令目录

          MAIL: 依据账号设置好用户的mailbox到/var/spool/mail/账号名

          USER: 根据用户的账号设置此变量内容

          HOSTNAME: 依据主机的hostname命令决定此变量内容

          HISTSIZE:历史命令记录条数

 

      /etc/profile不止会做这些事, 还会去调用外部的设置数据,下面这些数据会依序被调用进来:

        a. /etc/inputrc:  这个文件会主动判断用户有没有自定义输入的按键功能,如果没有,/etc/profile就会决定设置“INPUTRC=/etc/inputrc”这个变量。此文件内容为bash的热键、【Tab】键有没有声音等的数据。

        b. /etc/profile.d/*.sh:  只要在/etc/profile.d/这个目录内且扩展名为.sh,另外用户能够具有r的权限,那么该文件就会被/etc/profile调用。这个目录下面的文件规定了bash操作接口的颜色、语系、ll与ls命令别名、vi的命令别名、which的命令别名等。如果需要帮所有用户设置一些共享的命令别名时,可以在这个目录下面自行创建扩展名为.sh的文件,并将所需要的数据写入即可。

        c. /etc/sysconfig/i18n: 这个文件是由/etc/profile.d/lang.sh调用的。这也是我们决定bash默认使用何种语系的重要配置文件。文件里最重要的就是LANG这个变量的设置。

 

    注意:bash的login shell情况下所读取的整体环境配置文件其实只有/etc/profile,但是/etc/profile还会调用其他的配置文件。

    其实bash在都玩了整体环境设置的/etc/profile并借此调用其他配置文件后,接下来则是会读取用户的个人配置文件。在login shell的bash环境中,所读取的个人偏好配置文件其实主要有三个,依序分别是:

      ~/.bash_profile, ~/.bash_login, ~/.profile, 其实bash的loginshell设置只会读取上面三个文件的其中一个,而读取的顺序则是依照上面的顺序。

    读出顺序如下:

             

 

 

 

 (2):source: 读入环境配置文件的命令

    source 配置文件名

    . 配置文件名

    利用source或小数点(.)都可以将配置文件的内容读进目前的shell环境中。

 (3): non-login shell:

      当你取得non-login shell时, 该bash配置文件仅会读取~/.bashrc而已

  (4): /etc/bashrc帮我们的bash定义下面的数据:

      根据不同的UID规定umask的值

      依据不同的UID规定提示符(就是PS1变量)

      调用/etc/profile.d/*.sh的设置

  (5)、其他相关配置文件

    a、 /etc/man.config: 这个文件的内容规定了使用man的时候man page的路径到哪里去寻找。

    b、~/.bash_history: 每次登录bash后,bash会先读取这个文件,将所有的历史命令读入内存

    c、 ~/.bash_logout: 这个文件记录当我们注销bash后系统再帮我们做完什么操作后才离开

 

   4、终端机的环境设置: stty, set

    a、  查阅目前的一些按键内容: stty [-a]

      参数: -a : 将目前所有的stty参数列出来

      

  设置热键: 如 stty erase ^h       ^h--->[ctrl]+h

    

  eof: End of file 的意思,代表结束输入

  erase: 向后删除字符

  intr: 送出一个interrupt(中断)信号给目前正在运行的程序

  kill: 删除在目前命令行上的所有文字

  quit: 送出一个quit的信号给目前正在运行的进程

  start: 在某个进程停止后,重新启动它的输出

  stop: 停止目前屏幕的输出

  susp: 送出一个terminal stop的信号给正在运行的进程

 

  set 可以帮我们设置整个命令输出/输入的环境。例如记录历史命令、显示错误内容等。

  参数:

    -u: 默认不启用,若启用后,当使用未设置时,会显示错误信息。

    -v: 默认不启用,若启用后,在讯息被输出前,会先显示信息的原始内容

    -x: 默认不启用,若启用后,在命令被执行前,会显示命令内容(前面有++符号)

    -h: 默认启用,与历史命令有关

    -H: 默认启用,与历史命令有关

    -m: 默认启用,与工作管理有关

    -B:默认启用,与括号[]的作用有关

    -C: 默认不启用,使用>等时, 则若文件存在时,该文件不会被覆盖。

 

  b 、显示目前所有的set设置值: echo $- , 默认为himBH

  c、 另外我们还有其他的按键设置功能,就是在前一小节提到的/etc/inputrc这个文件里面设置。

   cat /etc/inputrc

 

   d、 bash默认的组合键给它汇整如表:

组合按键 执行结果
Ctrl+C 终止目前的命令
Ctrl+D 输入结束(EOF),例如邮件结束的时候
Ctrl+ M 就是Enter
Ctrl + S 暂停屏幕的输出
Ctrl+ Q 恢复屏幕的输出
Ctrl+U 在提示符下,将整行命令删除
Ctrl+ Z 暂停目前的命令

  

  5、通配符与特殊符号

    a、bash中的通配符

      

符号 意义
* 代表0个到无穷多个任意字符
代表一定有一个任意字符
[] 同样代表一定有一个在中括号内的字符(非任意字符)。例如[abc]代表一定有一个字符,可能是abc中的任一个 
[-] 若有减号在中括号内时,代表在编码顺序内的所有字符,例如[0-9]代表0到9之间的所有数字,因为数字的语系编码是连续的
[^] 若中括号内的第一个字符为指数符号(^),那表示原向选择,例如[^abc]代表一定有一个字符,只要是非a,b,c的其他字符就接受的意思

 

  特殊字符:

    

符号 内容
# 批注符号,这个最常被使用在script当中,视为说明。其后的数据均不执行
\ 转义字符,将“特殊字符或通配符”还原成一般字符
| 管道(pipe), 分隔两个管道命令的界定
; 连续命令执行分隔符,连续性命令的界定(注意,与管道命令不相同)
~ 用户的主文件
$ 使用变量前导符,即是变量之前需要加的变量替代值
& 作业控制(job control), 将命令变成背景下工作
!  逻辑运算意义上的“非”的意思
>,>> 数据流重定向,输出导向,分别是“替换”与“累加”
<,<< 数据重定向, 输入导向
'' 单引号,不具有变量置换的功能
"" 具有变量置换的功能
`` 两个“`”中间为可以先执行的命令,也可使用$()
() 在中间为子shell的起始于结束
{} 在中间为命令块的组合
   

 

五、数据流重定向

  数据重定向: 就是将某个命令执行后要出现在屏幕上的数据传输到其他的地方,例如文件或者是设备。

  1、什么是数据流重定向

    standard output 与 standard error output:

    标准输出指的是命令执行所回传的正确的信息, 而标准错误输出可理解为命令执行失败后,所回传的错误信息。

  

  数据重定向可以将standard output(简称stdout)与standard error output(简称stderr)分别传送到其他的文件或设备区,分别传送所用的特殊字符则如下所示:

  a、 标准输入(stdin): 代码为0,使用<或<<

  b、 标准输出(stdout): 代码为1, 使用>或>>

  c、 标准错误输出(stderr): 代码为2, 使用2> 或2>>

  

  覆盖于累加输出:

    单个>:覆盖    两个>(>>): 累加

  

   a、 /dev/null垃圾桶黑洞设备与特殊写法:

      /dev/null可以吃掉任何导向这个设备的信息。

      如 find /home -name .bashrc 2> /dev/null

    b、将正确与错误数据通通写入同一个文件的正确写法:

      find /home -name .bashrc >list 2>&1

      find /home ianme .bashrc &>list

   c、 standard input: < 与 <<:

      <: 将原本需要由键盘输入的数据改由文件内容来替代。

        例如: cat >file <~/.bashrc

      <<:代表结束输入的意思

 

  

 

   2、命令执行的判断依据: ; , &&, ||

    a、cmd;cmd(不考虑命令相关性的连续命令执行)

     b、$?(命令回传码)与&& 或 ||

   
cmd1 && cmd2 若cmd1执行完毕且正确执行($?=0), 则执行cmd2
若cmd1执行完毕且为错误($?!=0), 则不执行cmd2
cmd1 || cmd2 若cmd1执行完毕且正确执行($?=0), 则不执行cmd2
若cmd1执行完毕且为错误($?!=0), 则执行cmd2

六、管道命令(pipe)     

    管道命令: “|”仅能出来经由前面一个命令传来的正确信息,也就是standard output的信息,对于stdandard error并没有直接处理的能力。在每个管道后面接的第一个数据必定是“命令”, 而且这个命令必须要能够接收standard input的数据才行,这样的命令才可以是“管道命令”,如less,more, head, tail等都是可以接收standard input的管道命令。

    管道命令主要有两个比较需要注意的地方:

     管道命令必须要能够接收来自前一个命令的数据成为standard input继续处理才行

     管道命令仅会处理standard output, 对于standard error output会予以忽略

 

  2、选取命令: cut, grep

    a、cut命令将一段信息的某一段“切”出来,处理的信息以“行”为单位。

      cut -d '分隔字符' -f fields

      cut -c 字符范围

     参数:

      -d: 后面接分隔字符, 与-f一起使用

      -f: 依据-d的分隔字符将一段信息切割成为数段,用-f取出第几段的意思

      -c: 以字符的单位取出固定字符区间

    b、 grep:分析一行信息,若当中有我们所需要的信息,就将该行拿出来,简单的语法是这样的

        grep [-acinv] [--color=auto] '查找字符串' filename

        参数:

          -a: 将binary文件以text文件的方式查找数据

          -c: 计算找到‘查找字符串’的次数

          -i: 忽略大小写的不同,所以大小写视为相同

          -n: 顺便输出行号

          -v: 反向选择,即显示出没有‘查找符号’内容的那一行

          --color=auto: 可以将找到的关键字部分加上颜色显示

   

  3、排序命令:sort, wc, uniq

    a、sort: 帮我们进行排序,而且可以依据不同的数据类型来排序。例如数字与文字的排序就不一样。此外排序的字符与语系的编码有关。

    sort [-fbMnrtuk] [file or stdin]

    参数:

      -f: 忽略大小写的差异, 例如A与a视为编码相同

      -b: 忽略最前面的空格符部分

      -M: 以月份的名字来排序,例如JAN, DEC等的排序方法

      -n: 使用“纯数字”进行排序(默认是以文字类型排序)

      -r: 反向排序

      -u: 就是uniq,相同的数据中,仅出现一行代表

      -t: 分隔符, 默认是用【tab】键来分隔

      -k: 以那个区间(field)来进行排序的意思

    例如: /etc/passwd 内容以: 来分隔,我想以第三列来排序

        cat /etc/passwd | sort -t ':' -k 3

 

  b、uniq

    uniq [-ic]

    参数: 

      -i: 忽略大小写字符的不同

      -c: 进行计数

  c、 wc

    wc [-lwm]

    参数: 

      -l: 仅列出行

      -w: 仅列出多少字(英文单字)

      -m: 多少字符

    

  3、双向重定向: tee

    tee会同时将数据流送与文件与屏幕(screen);而输出到屏幕的,其实就是stdout,可以让下个命令继续处理:

    tee [-a] file

    参数:

      -a: 以累加的方式, 将数据加入file当中

     如: ls -l /home | tee ~/homefile | more

        将ls 的数据存一份到~/homefile,同时屏幕也有输出信息

 

   4、字符转换命令: tr, col, join, paste, expand

      a、 tr: 可以用来删除一段信息当中的文字, 或者是进行文字信息的替换

        tr [-ds] SET1 ...

       参数: 

        -d: 删除信息当中的SET1这个字符串

        -s: 替换掉重复的字符   

       例: 将last输出的信息中所有的小写字符变成大写字符

          last | tr '[a-z]' '[A-Z]'  
      

      b、 col: 可以用来进行简单处理,如将【tab】按键替换成为空格键

        

        col [-xb]

        参数: 

          -x: 将tab键转换成对等的空格键

          -b: 在文字内有反斜杠(/)时, 仅保留反斜杠最后接的那个字符

 

      c、join : 将两个文件当中有相同数据的那一行加在一起。

        jion [-ti12] file1 file2

        参数:

          -t: join默认以空格符分隔数据,并且对比“第一个字段”的数据

          -i: 忽略大小写的差异

          -1: 这个是数字的1, 代表第一个文件要用哪个字段来分析的意思

          -2: 代表第二个文件要用哪个字段来分析的意思

        例: /etc/passwd的第四个字段是GID, 那个GID记录在/etc/group当中的第三个字段,以GID整合两个文件

     join -t ':' -1 4 /etc/passwd -2 3 /etc/group

   注意: 在使用join之前,你所需要处理的文件应该要先经过排序(sort)处理,否则有些对比的项目会被略过。

      d、 paste: 介质将两行贴在一起,且中间以【tab】键隔开而已

      paste [-d] file1 file2

      参数:

        -d: 后面可以接分隔字符,默认是以【tab】来分隔

        -: 如果file部分写成-, 表示来自standard iput的数据的意思

 

      e、 expand:  将【tab】按键转成空格键, 可以这样做:

        expand [-t] file

        参数: 

          -t: 后面可以接数字。一般来说,一个【tab】按键可以用8个空格键替换,我们也可以自行定义一个【tab】代表多少个字符

      注: unexpand: 将空白转成【tab】命令

 

    5、切割命令:split

      如果你有文件太大,导致一些携带式设备无法复制的问题。split可以将一个大文件依据文件大小或行数来切割成为小文件。

    split [-bl] file PREFIX

    参数:

      -b: 后面可接欲切割的文件大小,可加单位,例如b,k, m等

      -l: 以行数来进行切割

      PREFIX: 可作为切割文件的前导文字

    6、参数代换: xargs

      产生某个命令的参数的意思。xargs可以读入stdin的数据,并且以空格符或断行字符进行分辨,将stdin的数据分隔成为arguents。

      xargs [-0epn] command

      -0: 如果输入的stdini含有特殊字符, 例如`, \, 空格键字符时, 这个参数可以将它还原成一般字符。这个参数可以用于特殊状态

      -e: 这个是EOF(end of file)的意思。后面可以接一个字符串,当xargs分析到这个字符串时,就会停止继续工作

      -p: 在执行每个命令的参数时, 都会询问用户的意思

      -n: 后面接次数,每次command命令执行时, 要使用几个参数的意思

      当xargs后面没有接任何的命令时, 默认是以echo来进行输出

    例如:  将/etc/passwd内的第一列取出,仅取三行, 使用finger这个命令将每个账号内容显示出来

      cut -d ':' -f 1 /etc/passwd | head -n 3 | xargs finger

 

    7、关于减号-的用途

      在管道命令中,经常会使用到前一个命令的stdout作为这次的stdin,某些命令需要用到文件名来进行处理时,该stdin与stdout可以利用减号“-”来替代,举例如下:

      tar -cvf - /home | tar -xvf -

      将/home里面的文件打包,但打包的数据不是记录到文件,而是传送到stdout;经过管道后,将tar -cvf - /home传送给后面的tar -xvf -后面的这个-则是取用前一个命令的stdout

 

  

 

posted on 2016-12-21 15:23  曾经的猪  阅读(4031)  评论(0编辑  收藏  举报