basename

用途:取得路径名称中最后的文件名部分

例:

[root@server shell]# basename /usr/local/bin/

bin

使用脚本同样有效果

[root@server shell]# cat baseNAME.sh

#!/bin/bash

#仿真basename指令

bn=${1##*/}

echo $bn

dirname

用途:取得路径名称中的目录部分。

例:

[root@server shell]# dirname /usr/local/bin/pcre

/usr/local/bin

使用脚本同样有效果

[root@server shell]# cat dirNAME.sh

#!/bin/bash

#仿真dirname指令

dn=${1%/*}

echo $dn

sort

用途:对文本文件的每一行做排序

例:

sort test.txt

test.txt做升幂排序(按ASCII的字符排序)

 

sort -r test.txt

test.txt做降幂排序(按ASCII的字符排序)

 

sort -n test.txt

test.txt做升幂排序(以字符串的数值大小为比较标准)

 

sort -k 2 test.txt

test.txt中的第2个字段做排序的依据(以字符串的方式比较)如果使用-n选项,则可以使用数值大小来比较

 

sort -nk 3 -t: test.txt

以:作为做分隔从第3个字段按数值大小做排序

 

uniq

用途:对已排序好的文件删除重复行

注:若重复列并未连续排在一起,则没有任何作用

 

 

sort test.txt |uniq

删除test.txt文件中重复行

 

sort test.txt |uniq -d

挑出重复行

 

sort test.txt |uniq -c

计算每一行重复的次数

 cut

用途:对文件的每一行抽出某一部分

 

cut -c 2 test.txt

抽出test.txt中每一行的第2个字符

 

cut -c3-10 test.txt

抽出test.txt中每一行的每3到第10个字符

 

cut -c10- test.txt

抽出test.txt中每一行第10个以后的字符

 

cut -c1-3,22- test.txt

抽出test.txt中每一行的第1到第3个字符以及第22个以后的字符

 

cut -d: -f1 test.txt

以:为做分隔符抽出test.txt文件中各行的第一个字段 -f1是第一个字段之意

paste

用途:对文件以行和行的方式合并

 

paste test.txt test1.txt

test.txt的每一行和test1.txt的每一行合并,默认以Tab做分隔

 

paste -d'#' test.txt test1.txt

test.txt的每一行和test1.txt的每一行合并,默认以#做分隔

 

paste -s test.txt

test.txt的每一行自己合并在一起,默认以Tab做分隔

tr

用途:转换或删除字符

 

tr r R < test.txt

test.txt文件中的r换成R

 

tr ':' '\n' < test.txt

test.txt中的:换成换行字符

 

tr -d r < test.txt

test.txt中的r删除

 

tr '[a-z]' '[A-Z]' < test.txt

test.txt中的所有小写字母转换成大写

 

tr -s '' '' < test.txt

将多余的空白删除只剩一个

 

grep

用途:显示符合样式的行

 

grep 'root' *

将当前文件中含有root的文件及行显示出来

 

grep  -i 'root' *

将当前文件中含有root的文件及行显示出来(不区分大小写)

 

grep  -nv 'root' test.txt

test.txt中不含root的行显示,-v是取反的意思,-n是显行号

 

grep -e 'index.html' /usr/local/apache/conf/httpd.conf

httpd.conf文件中含用index.html的行显示,-e是比较的样式