-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdek_clearance.py
executable file
·153 lines (117 loc) · 4.59 KB
/
dek_clearance.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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
"""
name : dek_clearance.py
author : nbehrnd@yahoo.com
license: GPLv2
date : <2023-06-04 Sun>
edit : <2023-06-28 Wed>
"""
import argparse
import os
import shutil
import sys
def get_args():
"""Get command-line arguments"""
parser = argparse.ArgumentParser(
description="""The optimization with svgcleaner may yield empty .svg,
and the .csv still may contain entries (now) irrelevant to the Anki deck to
assemble. This script lints the .csv and working directory accordingly.""",
formatter_class=argparse.ArgumentDefaultsHelpFormatter)
parser.add_argument('file',
help='the already once revised listing of addresses',
type=argparse.FileType('rt'),
default=None)
return parser.parse_args()
def remove_empty_files():
"""remove .svg which, after optimization, are empty
Overall, the optimization with `dek_optimize_5b.sh` proceeds faster, than
the one by `dek_optimize_5a.sh`, but sometimes yields an empty .svg. Move
these files into a separate folder."""
deposit = str("empty_svg")
empty = [] # files where optimization lead to be empty
try:
os.mkdir(deposit)
except IOError:
print(f"Folder {deposit} already exist, hence exit.")
sys.exit()
for file in os.listdir("."):
if file.endswith(".svg"):
if os.path.getsize(file) == 0:
shutil.move(file, deposit)
empty.append(file)
if empty:
print(f"Check {deposit} for {len(empty)} empty files.")
else:
os.rmdir(deposit)
def remove_entries_without_file(reference):
"""remove entries from the .csv without corresponding .svg
The .csv file may contain entries to .svg which do not exist (anymore).
To prevent presence of an Anki card with long hand form, but lacking a
short hand symbolization, remove these entries."""
new_list = []
with open(file=reference, mode="rt", encoding="utf-8") as source:
for line in source:
line = str(line).strip()
address = line.split("; ")[1]
address = address[10:-2]
if os.path.isfile(address):
new_list.append(line)
os.remove(reference)
with open(file=reference, mode="wt", encoding="utf-8") as new:
for entry in new_list:
new.write(f"{entry}\n")
def remove_files_without_reference(reference):
"""remove .svg files without entry in the .csv
There still may be .svg files in the current working directory which per
the listing in the .csv no longer are of interest. For now, these files
should be removed. This function aims to complement the one earlier."""
checklist = []
with open(file=reference, mode="rt", encoding="utf-8") as source:
for line in source:
line = str(line).strip()
address = line.split("; ")[1]
address = address[10:-2]
checklist.append(address)
check_set = set(checklist)
for file in os.listdir("."):
if str(file).endswith(".svg"):
if str(file) not in check_set:
os.remove(file)
def report_synopsis():
"""briefly list the population of the categories
Some of the symbolizations belong to a particular topical sub set, such as
`G_DEK` about geography, `L_DEK` about Latin, etc. This allows a training
based on this tag reflected in the files' file name and is an information
equally useful to report on the project's landing page."""
tag_listing = []
assistant_dictionary = {}
key_listing = []
for file in os.listdir("."):
if str(file).endswith(".svg"):
tag = str(file).split("+")[0]
tag_listing.append(tag)
for tag in tag_listing:
assistant_dictionary.setdefault(tag, 0)
assistant_dictionary[tag] = assistant_dictionary[tag] + 1
key_listing = list(assistant_dictionary.keys())
key_listing.sort()
# eventually report back to the CLI:
total = 0
print(f"{'set':5} {'entries':>8}")
print(5 * "-", 8 * "-")
for key in key_listing:
print(f"{key:5} {assistant_dictionary.get(key):8}")
total += int(assistant_dictionary.get(key))
print(5 * "-", 8 * "-")
print(f"{'sum':5} {total:8}")
def main():
"""Join the functionalities"""
args = get_args()
remove_empty_files()
remove_entries_without_file(args.file.name)
remove_files_without_reference(args.file.name)
report_synopsis()
# --------------------------------------------------
if __name__ == '__main__':
main()