-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
executable file
·66 lines (53 loc) · 2.03 KB
/
main.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
import os
import datetime
import shutil
import logging
import datetime
# settings
DAYS = 7
HOME_PATH = os.environ['HOME']
DESKTOP_PATH = os.path.join(HOME_PATH, "Desktop")
DOWNLOADS_PATH = os.path.join(HOME_PATH, "Downloads")
ARCHIVE_FOLDER_NAME = "Archive"
REMOVE_LIST = ['']
# #logging
ROOT_DIR = os.path.dirname(os.path.abspath(__file__))
LOG_FOLDER_PATH = os.path.join(ROOT_DIR, "log")
LOG_FILE_PATH = os.path.join(LOG_FOLDER_PATH, "info.log")
logging.basicConfig(filename=LOG_FILE_PATH, level=logging.INFO)
def move_to(current_path, oldFolder, days=7):
logging.debug(current_path)
dir = os.listdir(current_path)
today = datetime.date.today().strftime("%Y-%m-%d")
archive_folder = os.path.join(current_path, oldFolder)
if not os.path.exists(archive_folder):os.mkdir(archive_folder)
archive_folder = os.path.join(archive_folder,today)
if not os.path.exists(archive_folder): os.mkdir(archive_folder)
dead_line = datetime.date.today() - datetime.timedelta(days=days)
logging.debug(dead_line)
for file_name in dir:
logging.info("file_name:{}".format(file_name))
target = os.path.join(current_path, file_name)
logging.debug(target)
if target in REMOVE_LIST:
logging.debug('remove list name')
continue
if os.path.exists(target):
dt = datetime.datetime.fromtimestamp(os.stat(target).st_mtime)
key = dt.strftime('%Y/%m/%d %H:%M:%S')
logging.debug(str(key) + " - " + str(dt))
if (dt.date() < dead_line):
try:
shutil.move(target, archive_folder)
except Exception as e:
logging.warning(e)
shutil.rmtree(archive_folder)
shutil.move(target, archive_folder)
logging.info("moved")
else:
logging.info("keep")
logging.warning("Can't open " + file_name)
logging.debug("- - -")
if __name__ == '__main__':
move_to(DOWNLOADS_PATH, ARCHIVE_FOLDER_NAME, DAYS)
move_to(DESKTOP_PATH, ARCHIVE_FOLDER_NAME, DAYS)