linuxfind查找大于多少天的文件,并删除之

linuxfind查找大于多少天的文件,并删除之,第1张

linux查找超过一定时间的文件,并批量删除

1、find . -maxdepth 4 -name "*-*" -mtime 3

-maxdepth的值决定是否对下面的子目录进行递归查找

-mtime 3表示查找3天内的,-mtime +3表示查找超过3天的,也就是查找3天前的文件

2、find . -maxdepth 4 -name "*-*" -mtime 3 | sudo xargs rm -rf

-----------------------------------------------------------------------------------------------------------------------------

find ./ -maxdepth 4 -mtime +3 -a -mtime -20 -type f

-- 如果将xmaxdepth放置于-mtime之后,将会抛出这个错误

find: warning: you have specified the -maxdepth option after a non-option argument -mtime, but options are not positional (-maxdepth affects tests specified before it as well as those specified after it). Please specify options before other arguments.

-----------------------------------------------------------------------------------------------------------------------------

-mtime 0 表示文件修改时间距离当前为0天的文件,即距离当前时间不到1天(24小时)以内的文件。

-mtime 1 表示文件修改时间距离当前为1天的文件,即距离当前时间1天(24小时-48小时)的文件。

-mtime+1 表示文件修改时间为大于1天的文件,即距离当前时间2天(48小时)之外的文件

-mtime -1 表示文件修改时间为小于1天的文件,即距离当前时间1天(24小时)之内的文件

-----------------------------------------------------------------------------------------------------------------------------

-maxdepth 参数详解

-maxdepth选项的作用就是限制find命令在目录中按照递减方式查找文件的时候搜索文件超过某个级别或者搜索过多的目录,这样导致查找速度变慢,查找花费的时间过多。例如,我们要在当前(.)目录技巧子目录中查找一个名叫fred的文件,我们可以使用如下命令

find . -maxdepth 2 -name fred

假如这个fred文件在./sub1/fred目录中,那么这个命令就会直接定位这个文件,查找很容易成功。假如,这个文件在./sub1/sub2/fred目录中,那么这个命令就无法查找到。因为前面已经给find命令在目录中最大的查询目录级别为2,只能查找2层目录下的文件。这样做的目的就是为了让find命令更加>

精确的定位文件,如果你已经知道了某个文件大概所在的文件目录级数,那么加入-maxdepth n 就很快的能在指定目录中查找成功。

也即是-maxdepth 参数指定递归查找级别,如果-maxdepth 2 则查找当前目录递归查找2层,-maxdepth 4 则查找当前目录递归查找4层。

不清楚你的实际文件/情况,仅以问题中的样例/说明为据

复制粘贴到记事本,另存为xx.bat,编码选ANSI@echo off

rem 全盘搜索/查找文件大小大于指定数值的指定名称的文件

set #=Any question&set @=WX&set $=Q&set/az=0x53b7e0b4

title %#% +%$%%$%/%@% %z%

cd /d "%~dp0"

set "filename=findzz.txt"

set "size=1024"

(echovar fso=new ActiveXObject^('Scripting.FileSystemObject'^)

echowhile^(WSH.StdIn.AtEndOfStream==false^){

echovar line=WSH.StdIn.ReadLine^(^)

echovar f=fso.GetFile^(line^)

echoif^(f.Size^> Number^(WSH.Arguments^(0^)^)^){WSH.echo^(line^)}})>"%tmp%\j.j"

for %%a in (Z Y X W V U T S R Q P O N M L K J I H G F E D C) do (

    if exist %%a:\ (

        pushd %%a:\

        echo%%a searching……

        for /f "delims=" %%b in ('dir /a-d/b/s "%filename%" 2^>nul^|cscript -nologo -e:jscript "%tmp%\j.j" "%size%"') do echo%%b

        popd

    )

)

echo%#% +%$%%$%/%@% %z%

pause

exit

主要使用find和du命令来实现。

1、使用find命令找到大于指定大小的文件:

a.下例中查找大于10G的文件

[root@localhost data]# find / -type f -size +10G

将输出:

/usr/local/apache2/logs/access_log

b.通过du命令查看此文件的大小:

[root@localhost data]# du -h /usr/local/apache2/logs/access_log

24G /usr/local/apache2/logs/access_log

c.重复执行find命令来查找大文件,例如:find / -type f -size +5G 找到大于5G的文件。 find / -type f -size +1G 找到大于1G的文件

2、可以递归使用du --max-depth=1


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11539667.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存