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 -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是比较的样式