Linux查找和压缩文件:find、which、whereis、tar(下)

简介: 1 查找文件1.1 find采用递归方式,根据目标的名称、类型、大小等不同属性进行精细查找。命令的特点:

7)查找到文件后并做其他处理

# 找到img结尾的文件并删除的三种方式:
[root@localhost opt]# find -name "*.img" -delete               
[root@localhost opt]# find -name "*.img" -exec rm -rf {} \;
[root@localhost opt]# find -name "*.img" | xargs rm -rf
[root@localhost opt]# find -name "*.txt"  -ok mv {} /mnt \;   //查找.txt的文件并移动到/mnt目录下,对于每个文件执行命令之前,都会交互式要求用户确认
[root@localhost opt]# find -name "*.txt"  -exec mv {} /mnt \;   //查找.txt的文件并移动到/mnt目录下
复制代码


8)按时间查找:

#以“天”为单位:
find  -atime  [+/-]#      //按读取时间查找
#     //表示[#,#+1)
+#    //表示[#+1,+∞)
-#    //表示[0,#)
find  -mtime            //按文件内容改变时间查找
find  -ctime            //按元数据改变时间查找
#以“分钟”为单位:
-amin
-mmin
-cmin
find -mtime 10      //10天到11天,[10,11)
find -mtime +10     //代表11天以上,[11,+∞)
find -mtime -10     //10天以内,[0,10)
复制代码


9)比较“或”与“且”的优先级

[root@localhost opt]# find /etc/ -type d -o -type l |wc -l    //查找/etc目录下的目录和链接文件并统计数量
1008
[root@localhost opt]# find /etc/ -type d -o -type l -ls |wc -l   //查找/etc目录下的目录和链接文件,并显示链接文件的详细信息后统计数量
274 
[root@localhost opt]# find /etc/ -type d -o -type l -a -ls |wc -l    //此条命令与上条命令对比实际隐藏了一个-a(且),先执行了-type 1 -a -ls,处理动作只显示了链接文件
274
[root@localhost opt]# find /etc/ ( -type d -o -type l ) -a -ls |wc -l  //如果“或”和“且”实在需要一起显示,可以使用括号和转义符
1008
复制代码


10)反向查找,使用-not或!

[root@localhost d02]# ll      //查看目录下的文件及其属性
总用量 0
-rw-r--r--. 1 root root 0 2月  16 08:56 1.txt
-rw-r--r--. 1 root root 0 2月  16 08:56 2.txt
drwxr-xr-x. 2 root root 6 2月  16 08:55 dir0201
drwxr-xr-x. 2 root root 6 2月  16 08:55 dir0202
-rw-r--r--. 1 root root 0 2月  16 08:56 file01
-rw-r--r--. 1 root root 0 2月  16 08:56 file02
[root@localhost dir02]# find -not -type d   //使用-not,查找不是文件类型不是目录的文件
./1.txt
./2.txt
./file01
./file02
[root@localhost d02]# find ! -type d   //也可以使用!来代替-not,进行反向查找
./1.txt
./2.txt
./file01
./file02
[root@localhost d02]# find ! -type d ! -name "*.txt"   //查找不是目录且名称不以.txt结尾的文件
./file01
./file02
复制代码


11)找到/mnt目录下以f开头的文件,并全部加上后缀.bak

find /mnt -name f* -exec mv {} {}.bak \;
复制代码


12)找到文件并删除的三种方式:

find -name "*.img" -delete               
 find -name "*.img" -exec rm -rf {} \;
 find -name "*.img" | xargs rm -rf
复制代码


1.2 which

which 用来查看命令的位置。 在PATH变量指定的路径中,搜索某个系统命令的位置 。

命令格式:

which 命令/程序名

示例:

[root@localhost boot]# which ls    //查看ls命令文件的位置
alias ls='ls --color=auto'
        /usr/bin/ls
复制代码


1.3 whereis

whereis 用来查找命令的具体位置。可以查看到二进制文件(参数-b)、man说明文件(参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息。

示例:

[root@localhost ~]# whereis ls       //whereis 可以查找命令具体的位置所在
ls: /usr/bin/ls /usr/share/man/man1/ls.1.gz /usr/share/man/man1p/ls.1p.gz
复制代码


2 压缩文件


2.1 gzip和bzip2

gzip和bzip2都是压缩软件,比如windows里的好压和360压缩或微软自带的等等。

相同点:

  • 只能压缩文件 , 不能压缩目录
  • 默认压缩后会删除源文件。(bzip2可以使用-k保留源文件)

区别:

  • gzip比bzip2的压缩速度快,而bzip2的压缩率高于gzip。

命令格式:

  • 压缩:

gzip  [-9]  文件名…

bzip2 [-9]  文件名...

-1~9 指定压缩级别, 数字越大压缩级别越高 。-1最快压缩,-9最大压缩 。

  • 解压缩:

gzip -d .gz格式的压缩文件;

bzip2 -d .bz2格式的压缩文件

示例:

[root@localhost data]# ls
f1  f2
[root@localhost data]# bzip2 f1    //压缩后源文件被删除
[root@localhost data]# ls
f1.bz2  f2
[root@localhost data]# bzip2 -k f2    //使用-k保留源文件
[root@localhost data]# ls
f1.bz2  f2  f2.bz2
[root@localhost data]# bzip2 -d f1.bz2     //解压缩
[root@localhost data]# ls
f1  f2  f2.bz2
复制代码


2.2 归档tar 文件夹

tar (tape archive) 磁带归档,磁带便宜磁带机很贵,慢永久保存。

命令格式:

tar [选项] ... 归档文件名(压缩包名字) 源文件或目录 tar [选项] ... 归档文件名 [-C 目标目录]

选项说明:

  • -c:创建(Create).tar 格式的包文件
  • -x:解开.tar 格式的包文件
  • -C:解压时指定释放的目标文件夹 指定目录
  • -f:表示使用归档文件(一般都要带上表示使用tar)
  • -v:输出详细信息(Verbose)
  • -t:列出归档内容
  • -j:调用 bzip2 程序进行压缩或解压
  • -z:调用 gzip 程序进行压缩或解压

示例:

[root@localhost data]# tar -zcvf vm.tar.gz f1 f2 f3   //将三个文件归档后调用gzip程序压缩成vm.tar.gz
f1
f2
f3
[root@localhost data]# tar -jcvf vm.tar.bz f1 f2 f3   //将三个文件归档后调用bzip2程序压缩成vm.tar.bz2
f1
f2
f3
[root@localhost data]# tar -zxvf vm.tar.gz -C /opt    //将vm.tar.gz文件解压缩到/opt目录下
f1
f2
f3
[root@localhost data]# tar -tf ff.tar.gzip    //列出归档内容
file01
file02
[root@localhost data]# tar -tvf /tmp/ceshi/ff.tar   //详细列举归档文件中的所有文件(包括属性信息)
-rwxr--r-- root/root        87 2022-01-21 17:37 file01
-rw-r--r-- user01/hr         0 2022-01-19 17:01 file02
相关文章
|
23天前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
55 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
9天前
|
Ubuntu Linux Go
golang编译成Linux可运行文件
本文介绍了如何在 Linux 上编译和运行 Golang 程序,涵盖了本地编译和交叉编译的步骤。通过这些步骤,您可以轻松地将 Golang 程序编译成适合 Linux 平台的可执行文件,并在目标服务器上运行。掌握这些技巧,可以提高开发和部署 Golang 应用的效率。
67 14
|
8天前
|
存储 NoSQL Linux
linux积累-core文件是干啥的
核心文件是Linux系统在程序崩溃时生成的重要调试文件,通过分析核心文件,开发者可以找到程序崩溃的原因并进行调试和修复。本文详细介绍了核心文件的生成、配置、查看和分析方法
41 6
|
10天前
|
存储 NoSQL Linux
linux之core文件如何查看和调试
通过设置和生成 core 文件,可以在程序崩溃时获取详细的调试信息。结合 GDB 等调试工具,可以深入分析 core 文件,找到程序崩溃的具体原因,并进行相应的修复。掌握这些调试技巧,对于提高程序的稳定性和可靠性具有重要意义。
53 6
|
2月前
|
Linux 开发工具 Perl
在Linux中,有一个文件,如何删除包含“www“字样的字符?
在Linux中,如果你想删除一个文件中包含特定字样(如“www”)的所有字符或行,你可以使用多种文本处理工具来实现。以下是一些常见的方法:
44 5
|
Linux 开发工具
Linux vi vim 查找和替换字符串 命令
一、vi查找: 当你用vi打开一个文件后,因为文件太长,如何才能找到你所要查找的关键字呢?在vi里可没有菜单-〉查找,不过没关系,你在命令模式下敲斜杆(/)这时在状态栏(也就是屏幕左下脚)就出现了 “/”然后输入你要查找的关键字敲回车就可以了。
3399 0
|
Linux
Linux用ctrl + r 查找以前(历史)输入的命令
在Linux系统下一直用上下键查找以前输入的命令,这个找刚输入不久的命令还是很方便的,但是比较久远的命令,用上下键效率就不高了。那个history命令也是个花架子,虽然功能多,但不好用,网上找了下,发现了用ctrl + r这个快捷键查找历史命令,研究了一下发现真是好用。
1366 0
|
Linux Shell 数据库