1.cat

(1)基本用法

[root@cai tmp]# cat 1.txt  2.txt
this is a test1
this is a test 2

(2)cat -s file(删除额外空白行)

[root@cai tmp]# cat .txt
a b c d
[root@cai tmp]# cat -s .txt
a b c d

(3)cat -n lines.txt (显示行号)

[root@cai tmp]# cat -s -n .txt
a b c d

2.录制并回放终端回话(script/scriptreplay)

()[root@cai tmp]# script -t >timing.log -a output.session(录制)
Script started, file is output.session
()[root@cai tmp]# scriptreplay timing.log output.session (回放)

3.文件查找与文件列表(find)

(1)find base_path(顺着目录,向下查找)

[root@cai tmp]# find /tmp/
/tmp/
/tmp/.ICE-unix
/tmp/output.session
/tmp/Aegis-<Guid(5A2C30A2-A87D-490A--6765EDAD7CBA)>
/tmp/.txt
/tmp/.txt
/tmp/.txt
/tmp/test.txt

(2)find . -iname "*.txt" -print(忽略要查找内容大小写)

[root@cai tmp]# find . \( -name "*.txt" -o -name "*.log" \)
./.txt
./.txt
./.txt
./test.txt

(3)find / -path "*/cairui/*"

[root@cai tmp]# find / -path "*/cairui/*"
/home/cairui/tools
/home/cairui/tools/nginx-1.12..tar.gz
/home/cairui/tools/mysql-5.7.-linux-glibc2.-x86_64.tar.gz
/home/cairui/tools/nginx-1.12.
/home/cairui/tools/nginx-1.12./Makefile
/home/cairui/tools/nginx-1.12./man
/home/cairui/tools/nginx-1.12./man/nginx.

(4)否定参数(!)

[root@cai tmp]# ls
.txt Aegis-<Guid(5A2C30A2-A87D-490A--6765EDAD7CBA)> test3.txt
.txt output.session timing.log
[root@cai tmp]# find . ! -name "*.txt"(打印出不是以.txt结尾的文件)
.
./.ICE-unix
./timing.log
./output.session
./Aegis-<Guid(5A2C30A2-A87D-490A--6765EDAD7CBA)>

(5)基于目录深度的搜索(maxdepth)

find . -maxdepth  -name “f*” -print

[root@cai tmp]# find / -maxdepth  -path "*/cairui/*"
/home/cairui/tools
/home/cairui/.bash_profile
/home/cairui/.bash_logout
/home/cairui/.bashrc

(6)根据文件类型搜索

[root@cai tmp]# find . -type d -print(只列出所有的目录)
.
./.ICE-unix [root@cai tmp]# find . -type f (只列出文件)
./timing.log
./output.session
./test3.txt
./.txt
./.txt

文件类型

参数类型

普通文件

f

符号链接

l

目录

d

字符设备

c

块设备

b

套接字

s

FIFO

p

(7)根据文件时间进行搜索

访问时间(-atime):用户最近一次访问文件的时间。

修改时间(-mtime):文件内容最后一次被修改的时间。

变化时间(-ctime):文件元数据(例如权限和所有权)最后一次改变的时间。

[root@cai tmp]# find . -type f -atime - (打印出最近7天内访问过的所有文件)
./timing.log
./output.session
./test3.txt
./.txt
./.txt [root@cai tmp]# find . -type f -atime (正好在7天前那天访问的文件)
[root@cai tmp]# find . -type f -atime + (访问时间超过7天的所有文件)

上面是按照天计算的,同样有按分钟计算的

-amin(访问时间)

-mmin(修改时间)

-cmin(变化时间)

(8)基于文件大小的搜索

find . -type f -size +2k(大于2K的文件)

find . -type f -size -2k(小于2k的文件)

find . -type f -size 2k(等于2k的文件)

除了k,还有其他的

b---块(512字节)

c---字节

w---字(2字节)

k---1024字节

M---1024k字节

G---1024M字节

(9)删除匹配的文件(-delete)

find . type f -name “*.txt” -delete

(10)利用find执行命令或动作(-exec)

find .type f -user root -exec chown slynux {} \;

find . type f -name “*.c” -exec cat {} \;>all_c_files.txt

4.玩转xargs

擅长将标准输入数据转换成命令行参数。

(1)将多行输入转换成单行输出

[root@cai tmp]# cat ex.txt

[root@cai tmp]# cat ex.txt |xargs
  

(2)将单行输入转换为多行输出

[root@cai tmp]# cat ex.txt |xargs -n

(3)

[root@cai tmp]# cat ex.txt
splitXsplitXsplitX [root@cai tmp]# cat ex.txt |xargs -d X(用自己的分隔符来分割参数)
split split split

5.用tr进行转换

tr [option] test1 test2
()[root@cai tmp]# echo "HELLO WORLD" |tr 'A-Z' ‘a-z’ ()[root@cai tmp]# echo |tr '0-9' ''(加密) [root@cai tmp]# echo |tr '' '0-9'(解密) ()删除字符(tr -d)
[root@cai tmp]# echo "hello 122 world 55"|tr -d '0-9'
hello world ()用tr压缩字符(tr -s)
[root@localhost ~]# echo "cairui is so handsome " | tr -s ' '
cairui is so handsome [root@localhost tmp]# cat test.txt [root@localhost tmp]# cat test.txt | echo $[ $(tr '\n' '+' ) ]

6.检验与核实

(1)

[root@localhost tmp]# md5sum test.txt
a7b1ac3a2b072f71a8e0d463bf4eb822 test.txt

如上所示,md5sum是一个32个字符的十六进制串

将输出的检验和重定向到一个文件,然后用md5文件核实数据的完整性

(2)

[root@localhost tmp]# md5sum -c test_sum.md5
test.txt: 确定(检验是否匹配)                              

7.加密工具与散列

(1)

crypt
crypt <input_file >output_file
ENTER passphrase
()gpg
[root@localhost tmp]# gpg -c test.txt(加密,保证在传输过程中无法读取) [root@localhost tmp]# gpg test.txt(解密)

8.排序、唯一与重复

()
[root@localhost tmp]# sort .txt .txt > sorted.txt
[root@localhost tmp]# cat sorted.txt dfzcx
dq
kdfi
[root@localhost tmp]# cat .txt [root@localhost tmp]# cat .txt
kdfi
dfzcx
dq

(2)按照数字顺序进行排序

[root@localhost tmp]# sort -n .txt

(3)按照逆序进行排序

[root@localhost tmp]# sort -r .txt

(4)按照月份进行排序(依照一月、二月、三月、、、、)

sort -M months.txt

(5)按照两个已排序过的文件

sort -m sorted1 sorted2

(6)找出已排序文件中不重复的行

sort file.txt file2.txt |uniq

(7)检查文件是否已经排序过

#!/bin/bash
#function:paixu
sort -C filename;
if [ $? eq ]; then
echo sorted;
else
echo unsorted;
fi

9.分割文件和数据

split -b 10k data.file
ls
data.file xaa xab xac.......

10.根据扩展名切分文件名

#!/bin/bash
#function:根据扩展名切分文件名
file_jpg="sample.jpg"
name=${file_jpg%.*} (name=${file_jpg#*.})
echo file name is:$name
[root@localhost shell]# sh sample.sh
file name is:sample

11.批量重命名和移动

#!/bin/bash
#用途:重命名.jpg和.png文件 count=;
for img in ‘find . -iname ‘*.png’ -o -iname ‘*.jpg’ -type f -maxdepth ’
do
new=image-$count.${img##*.}
echo “renaming $img to $new”
mv “$img” “$new”
let count++
done

12.交互输入自动化

#!/bin/bash
read -p "enter number:" no;
read -p "enter name:" name
echo you have entered $no,$name
[root@localhost shell]# echo -e "1\nhello\n" | ./interactive.sh
you have entered ,hello
05-21 08:59