#! /usr/bin/python2.6
#-*- encoding:UTF-8 -*-

import os
import os.path
import time

root_dir = os.getcwd()
seperator = os.sep

max_used_space = 60*1024*1024*1024 #当使用的硬盘空间大于该值的时候启动删除60G
min_left_space = 20*1024*1024*1024 #删除保存的硬盘空间20G
max_remain_time = 7*24*60*60 #文件最大允许保存的时间为一周时间

file_list = []

def show_dirinfo(root_dir):
for parent, dirnames, filenames in os.walk(root_dir):
if len(filenames) > 0: #当前访问的文件夹下有文件存在
show_fileinfo(parent, filenames)

if len(dirnames) > 0: #当前访问的文件夹下还有子文件夹,递归访问
for dirname in dirnames:
if parent.endswith(seperator):
show_dirinfo(parent + dirname)
else:
show_dirinfo(parent + seperator + dirname)
del dirnames[0] #该文件夹已经访问过了,需要删除

if (len(filenames) == 0) and (len(dirnames) == 0): #空文件夹就删除
try:
os.rmdir(parent) ###############删除空文件夹#################
except Exception as e:
pass

def show_fileinfo(parent_dir, filenames):

for filename in filenames: #输出文件信息
full_path_name = os.path.join(parent_dir, filename)
try:
statinfo=os.stat(full_path_name)
except Exception as e:
return

file_size = statinfo.st_size
file_midifytime = statinfo.st_mtime

temp_dict = dict(zip(['filename', 'filesize', 'filetime'], [full_path_name, file_size, file_midifytime]))
#if file_size > 512*1024*1024:
save_file(temp_dict)

def save_file(temp_dict):
global file_list

insert_succ = 0 #判断是否插入成功

new_time = temp_dict['filetime']

if len(file_list) == 0:
file_list.append(temp_dict)
else:
for i in range(len(file_list)):
old_time = file_list[i]['filetime']
if new_time < old_time: #时间越久数值越小,按照时间排序,时间值越小也就是越久的文件排在最前面,删除的时候优先删除
file_list.insert(i, temp_dict)
insert_succ = 1
break

if insert_succ == 0: #没有插入成功表示当前的文件是新文件,需要放在最后面
file_list.append(temp_dict)

def delete_file():
global file_list
global max_used_space
global min_left_space
global max_remain_time

file_count = len(file_list)
file_index = 0

now_time = time.time()

while (file_index < (file_count - 1)):
file_midifytime = file_list[file_index]['filetime']
full_path_name = file_list[file_index]['filename']

if (now_time - file_midifytime) >= max_remain_time: #该文件的时间已经超过一周了,需要删除
try:
os.remove(full_path_name) #####################删除文件了#########################
del file_list[file_index]

file_count = file_count - 1
file_index = file_index - 1
except Exception as e:
return

file_index = file_index + 1
else:
break

total_file_size = get_total_file_size() #获得总的文件大小信息

if total_file_size > max_used_space: #如果大于上限就开始执行删除操作
while (total_file_size > min_left_space): #删除保留空间大小
delete_file_name = file_list[0]['filename'] #从头开始删除,因为已经排序了
delete_file_size = file_list[0]['filesize']
os.remove(delete_file_name) #执行删除操作
del file_list[0] #从文件列表中删除
total_file_size = total_file_size - delete_file_size #重新计算总的文件大小

def get_total_file_size(): #计算整个文件的大小
global file_list

total_size = 0.0
for i in range(len(file_list)):
total_size = total_size + file_list[i]['filesize']

try:
show_dirinfo(root_dir)
print(str(file_list))
#delete_file()
except Exception as e:
print(e)

python 遍历删除日志的更多相关文章

  1. python遍历删除列表的方法

    for item in list(somelist): somelist.remove(item)

  2. python 遍历list并删除部分元素

    python 遍历list并删除部分元素https://blog.csdn.net/afgasdg/article/details/82844403有两个list,list_1 为0-9,list_2 ...

  3. python 多线程删除MySQL表

    一.需求分析 在<python 统计MySQL表信息>这篇博客中,链接如下: https://www.cnblogs.com/xiao987334176/p/9901692.html 已经 ...

  4. 用Python遍历目录

    用Python遍历指定目录下的文件,一般有两种常用方法,但它们都是基于Python的os模块.下面两种方法基于Python2.7,主要用到的函数如下: 1.os.listdir(path):列出目录下 ...

  5. python遍历目录文件脚本的示例

    例子 自己写的一个Python遍历文件脚本,对查到的文件进行特定的处理.没啥技术含量,但是也记录一下吧. 代码如下 复制代码 #!/usr/bin/python# -*- coding: utf-8 ...

  6. python之配置日志的三种方式

    以下3种方式来配置logging: 1)使用Python代码显式的创建loggers, handlers和formatters并分别调用它们的配置函数: 2)创建一个日志配置文件,然后使用fileCo ...

  7. Python之配置日志的几种方式(logging模块)

    原文:https://blog.csdn.net/WZ18810463869/article/details/81147167 作为开发者,我们可以通过以下3种方式来配置logging: 1)使用Py ...

  8. 【转】python之配置日志的几种方式

    [转]python之配置日志的几种方式 作为开发者,我们可以通过以下3种方式来配置logging: 1)使用Python代码显式的创建loggers, handlers和formatters并分别调用 ...

  9. Python中的日志处理

    在日常项目中,总是需要记录下一些细小信息或者错误码.错误信息的,这个时候就需要进行日志的操作.python中用于日志创建.设置和记录等功能的模块,就是logging了,下面是对其基本使用方法的介绍: ...

随机推荐

  1. UVa 10891 (博弈+DP) Game of Sum

    最开始的时候思路就想错了,就不说错误的思路了. 因为这n个数的总和是一定的,所以在取数的时候不是让自己尽可能拿的最多,而是让对方尽量取得最少. 记忆化搜索(时间复杂度O(n3)): d(i, j)表示 ...

  2. ASP.NET路由系统实现原理:HttpHandler的动态映射

    我们知道一个请求最终通过一个具体的HttpHandler进行处理,而我们熟悉的用于表示一个Web页面的Page对象就是一个HttpHandler,被用于处理基于某个.aspx文件的请求.我们可以通过H ...

  3. find命令下的atime,ctime,mtime

    Linux下的find命令在目录结构中搜索文件,并执行指定的操作.linux下的find命令提供了相当多的查找条件,功能很强大,由于find的功能很强大,所以他的选项也很多,今天我们来细说一下find ...

  4. (转)Python 字典排序

    我们知道Python的内置dictionary数据类型是无序的,通过key来获取对应的value.可是有时我们需要对dictionary中 的item进行排序输出,可能根据key,也可能根据value ...

  5. 【网络】TCP三次握手

    在TCP/IP协议中,TCP协议提供可靠的连接服务,采用三次握手建立一个连接.第一次握手:建立连接时,客户端发送syn包(syn=j)到服务器,并进入SYN_SEND状态,等待服务器确认:第二次握手: ...

  6. RAC 环境下的重要参数

    Oracle 数据库启动时会根据参数文件中提供的相关参数启动Oracle实例.这些参数包括数据库名字.sga,pga的分配,控制文件的位置,undo,process等等.Oracle RAC数据库同样 ...

  7. JBPM4之decision节点:3、程序猿|菜鸟|攻城狮|牛人

    JBPM入门系列文章: JBPM4入门——1.jbpm简要介绍 JBPM4入门——2.在eclipse中安装绘制jbpm流程图的插件 JBPM4入门——3.JBPM4开发环境的搭建 JBPM4入门—— ...

  8. Mysql查询优化器

    Mysql查询优化器 本文的目的主要是通过告诉大家,查询优化器为我们做了那些工作,我们怎么做,才能使查询优化器对我们的sql进行优化,以及启示我们sql语句怎么写,才能更有效率.那么到底mysql到底 ...

  9. 502 Bad Gateway nginx 解决

    打开 /usr/local/php/etc/php-fpm.conf 调大以下两个参数(根据服务器实际情况,过大也不行) <value name=”max_children”>5120&l ...

  10. 模式自由(Schema-free)和数据存储的非格式化趋势

    最近遐想,数据存储的非格式化趋势. 格式化表格到自由的XML存储 数年以前,多家数据库厂商开始XML数据库存储.XML数据作为一种自描述的半结构化数据为Web的数据管理提供了新的数据模型,如果将XML ...