当前位置: 首页 > 编程笔记 >

Ruby实现的一个强大的批量删除文件脚本分享

乐修远
2023-03-14
本文向大家介绍Ruby实现的一个强大的批量删除文件脚本分享,包括了Ruby实现的一个强大的批量删除文件脚本分享的使用技巧和注意事项,需要的朋友参考一下

最近打包服务器上的apk包又增多了,每次手动rm操作过于麻烦,于是花了几分钟写了一个可以对指定目录下根据最后修改时间和通配符匹配进行批量删除的脚本。将这个脚本加入crontab中之后,以后就再也不用担心多余的安装包占用磁盘空间了。

简短的代码


#!/usr/bin/env ruby

# encoding: utf-8

#Usage: ruby removeOldFiles.rb "dest_file_pattern" days_ago

destFilePattern= ARGV[0]

daysAgo= ARGV[1]

edenTime = Time.now.to_i - daysAgo.to_i * 86400

Dir[destFilePattern].each{|child|

    system "rm -rfv #{child}"   if (File.mtime(child).to_i < edenTime)

}

如何使用

使用起来很简单,使用规则如下


ruby removeOldFiles.rb "dest_file_pattern" days_ago

举个例子,比如我们想删除/tmp目录下的,所有最后修改时间为3天前的apk文件,我们只需要这样执行。


ruby removeOldFiles.rb "/tmp/*.apk" 3

为什么第一个参数使用双引号

第一个参数为包含通配符的路径,在shell中存在一个工具就是glob会将包含通配符的路径匹配到具体的文件,比如这样的一段代码。


!/usr/bin/env ruby

# encoding: utf-8

puts ARGV.length

ARGV.each do |a|

    puts "Argument: #{a}"

end

我们传入含有通配符的路径参数,得到的结果就是glob匹配后的文件名(前提是通配符可以匹配到文件)。


10:41 $ ruby test.rb *.txt

2

Argument: abc.txt

Argument: def.txt


为了避免进行glob操作,需要对包含通配符的路径参数使用双引号标记。


10:41 $ ruby test.rb "*.txt"

1

Argument: *.txt

所以在使用脚本时第一个参数一定要使用双引号。

如何遍历文件包含子目录内的

比如我们想遍历/tmp/abc/def.txt 我们可以使用/tmp/**/.txt即可

 类似资料:
  • 本文向大家介绍ruby实现的文件自删除代码分享,包括了ruby实现的文件自删除代码分享的使用技巧和注意事项,需要的朋友参考一下 因为windows的文件删除机制和unix like的不一样,so不保证如下代码能在windows中使用,哪位童鞋帮我在windows中测试一下也好啊! 最后2句意思是你可以伪造代码或者干脆毁尸灭迹...

  • 本文向大家介绍Ruby实现的删除已经合并的git分支脚本分享,包括了Ruby实现的删除已经合并的git分支脚本分享的使用技巧和注意事项,需要的朋友参考一下 使用Git管理代码工程,着实方便了很多,但是当做完feature分支或者完成hotfix之后,总是忘记删除这些无用的分支,一个一个地删除着实麻烦,重复手工劳动不符合程序员的风格,于是写了一个简单的脚本。一键删除那些不需要的分支,让多余的干扰信息

  • 本文向大家介绍Shell脚本实现删除一年前文件功能分享,包括了Shell脚本实现删除一年前文件功能分享的使用技巧和注意事项,需要的朋友参考一下

  • 我有这个批处理文件来拆分txt文件: 它可以工作,但它一行一行地拆分它。我如何让它每5000行拆分一次。提前感谢。 编辑: 但我得到一个错误提示:<code>没有足够的存储空间来处理此命令。<code>

  • 本文向大家介绍thinkPHP批量删除的实现方法分析,包括了thinkPHP批量删除的实现方法分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了thinkPHP批量删除的实现方法。分享给大家供大家参考,具体如下: html: php: 原理是根据Web表单提交时可以传递数组,例如: 则传递过来的是: 更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》

  • 本文向大家介绍mysql 大表批量删除大量数据的实现方法,包括了mysql 大表批量删除大量数据的实现方法的使用技巧和注意事项,需要的朋友参考一下 问题参考自:https://www.zhihu.com/question/440066129/answer/1685329456 ,mysql中,一张表里有3亿数据,未分表,其中一个字段是企业类型,企业类型是一般企业和个体户,个体户的数据量差不多占50