python使用笔记13--清理日志小练习
1 '''
2 写一个删除日志的程序,删除5天前或为空的日志,不包括当天的
3 1.删除5天前的日志文件
4 2.删除为空的日志文件
5 '''
6 import os
7 import time
8
9 def delete_logs_file():#清理日志
10 for cur_dir,dirs,files in os.walk('logs'):
11 print(cur_dir,dirs,files)
12 if files:#当文件列表不为空是,开始删除
13 for file_name in files:
14 file_time = get_filename_time(file_name)#获取文件名的时间
15 is_delete_file = check_time(file_time)
16 file_path = os.path.join(cur_dir,file_name)
17 if is_delete_file:
18 os.remove(file_path)
19 else:
20 if check_time_is_today(file_time):#文件时间不是今天
21 if check_file_content(file_path):#文件为空,可以删除
22 print('文件为空',file_path)
23 os.remove(file_path)
24
25
26
27 def get_filename_time(file_name):#获取文件名中的时间
28 if file_name:
29 temp = file_name.split('_')
30 file_name_time = temp[1][:10]
31 return file_name_time
32
33 def check_time_is_today(time_str):#判断时间是否为当天
34 today = time.strftime('%Y-%m-%d')#获取当天的格式化时间
35 if today == time_str:
36 return False
37 else:
38 return True
39
40 def check_time(time_str):#判断时间是否为5天前的时间
41 now_time = time.time()#获取当前的时间戳
42 day_ago = now_time-5*24*60*60#获取5天前的时间戳
43 temp_time = time.strptime(time_str,'%Y-%m-%d')#获取传入时间的元组
44 time_zone = time.mktime(temp_time)
45 if time_zone <= day_ago:
46 return True
47 else:
48 return False
49
50 def delete_file(file_path):#删除指定文件
51 os.remove(file_path)
52
53 def check_file_content(file_path):#判断文件是否为空
54 file_size = os.path.getsize(file_path)
55 if file_size == 0:
56 return True
57 else:
58 return False
59
60 delete_logs_file()
python使用笔记13--清理日志小练习的更多相关文章
- python 学习笔记 13 -- 经常使用的时间模块之time
Python 没有包括相应日期和时间的内置类型.只是提供了3个相应的模块,能够採用多种表示管理日期和时间值: * time 模块由底层C库提供与时间相关的函数.它包括一些函数用于获取时钟时间和处 ...
- Python 学习笔记13:Python + wsgi + django 配置。坑爹的python3和wsgi不兼容的解决
今人不见古时月,今月曾经照古人.生命是如此的美丽与短暂! 学习Python已经两个月了,Python的语法通过做简单的语法题和看Python语法介绍,有了初步的了解.但上班还是要做别的事情,所以感觉学 ...
- python学习笔记(13):python并发编程以及系统常用模块
一.进程与线程 1.进程:程序的一次执行(程序装载入内存,系统分配资源运行).n 每个进程有自己的内存空间.数据栈等,只能使用进程间通讯,而不能直接共享信息 2.线程:所有线程运行在同一个进程中,共享 ...
- Python入门笔记(13):列表解析
一.列表解析 列表解析来自函数式编程语言(haskell),语法如下: [expr for iter_var in iterable] [expr for iter_var in iterable i ...
- Python学习笔记13—错误和异常
常见的异常:
- HTML5自学笔记[ 13 ]canvas绘图小实例之方块移动
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- python学习笔记13(模块、包)
在Python中有一个概念叫做模块(module),比如在Python中要调用sqrt函数,必须用import关键字引入math这个模块,下面就来了解一下Python中的模块. 模块文件以.py后缀结 ...
- Python学习笔记13:标准库之子进程(subprocess包)
ubprocess包主要功能是运行外部的命令和程序.从这个意义上来说,subprocess的功能与shell类似. subprocess以及经常使用的封装函数 当我们执行python的时候,我们都是在 ...
- Python 学习笔记13 类 - 创建和简单使用
介绍: 面向对象编程是一种非常有效的软件编写方法之一,在面向对象编程中,我们会编写表示现实世界中的事物或者情景的类,并基于类来创建对象. 在编写类的的时候,这些类对象一般都有通用的行为或者属性.基于类 ...
随机推荐
- PaddlePaddle推理部署
PaddlePaddle推理部署 飞桨推理产品简介 作为飞桨生态重要的一部分,飞桨提供了多个推理产品,完整承接深度学习模型应用的最后一公里. 整体上分,推理产品主要包括如下子产品 各产品在推理生态中的 ...
- TVM 优化 ARM GPU 上的移动深度学习
TVM 优化 ARM GPU 上的移动深度学习 随着深度学习的巨大成功,将深度神经网络部署到移动设备的需求正在迅速增长.与桌面平台上所做的类似,在移动设备中使用 GPU 既有利于推理速度,也有利于能源 ...
- 菜鸟刷题路:剑指 Offer 05. 替换空格
剑指 Offer 05. 替换空格 class Solution { public String replaceSpace(String s) { StringBuilder str = new St ...
- RabbitMQ由浅入深入门全总结(二)
写在最前面 距离上一次发文章已经很久了,其实这段时间一直也没有停笔,只不过在忙着找工作还有学校结课的事情,重新弄了一下博客,后面也会陆陆续续会把文章最近更新出来~ 这篇文章有点长,就分了两篇 PS:那 ...
- 彻底搞懂彻底搞懂事件驱动模型 - Reactor
在高性能网络技术中,大家应该经常会看到Reactor模型.并且很多开源软件中都使用了这个模型,如:Redis.Nginx.Memcache.Netty等. 刚开始接触时可能一头雾水,这到底是个什么东东 ...
- 02:database 配置(可能出现严格模式配置问题)
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'day42', 'USER': 'root', 'P ...
- k8s-记一次安全软件导致镜像加载失败
近期在现场项目中遇到了一个镜像加载失败的问题,相关报错如下: Error processing tar file(exit status 1): symlink . /usr/bin/X11: per ...
- TOP-5错误率
TOP-5错误率是指每幅图像同时用5个类别标签进行预测:如果其中任何一次预测正确,就认为预测正确,如果5次预测的结果都错了,才认为预测错误,这时的分类错误率就是TOP-5错误率.
- 遇到禁止复制该怎么办?幸好我会Python...
相信大家都有遇到这种情况(无法复制): 或者是这种情况 以上这种情况都是网页无法复制文本的情况.不过这些对于Python来说都不是问题.今天辰哥就叫你们用Python去解决. 思路:利用pdfkit库 ...
- docker2-镜像原理及创建新的镜像
1,镜像是什么 镜像是一种轻量级.可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需的所有内容,包括代码.运行时.库.环境变量和配置文件 在docker中所有应用 ...