seminarwahl_cleaner/seminarwahl_cleaner.py

112 lines
3.2 KiB
Python

import re
import sys
import io
import tkinter as tk
import tkinter.filedialog as tkfd
import tkinter.messagebox as tkm
root = tk.Tk()
root.rowconfigure(0, weight=1)
root.rowconfigure(0, weight=3)
root.columnconfigure(0, weight=1)
root.columnconfigure(1, weight=1)
root.columnconfigure(2, weight=1)
root.columnconfigure(3, weight=1)
content = ""
content_lines = list()
newcontent = ""
fname = ""
if sys.platform == "win32":
out_encoding = "cp1252"
else:
out_encoding = "utf-8"
def load_file(event=None):
global content
global content_lines
global fname
fname = tkfd.askopenfilename(filetypes=(("CSV files","*.csv"),("text files","*.txt")))
try:
f = io.open(fname, mode='rt', encoding='utf-8', newline="") # mit allen Steuerzeichen
content = f.read()
content = content.replace("\r","")
content_orig_lines = content.split("\n")
for line in content_orig_lines:
line = line.replace("\r","")
print(line)
content_lines.append(line)
t_preview.insert(0.0,content)
f.close()
except Exception as e:
print(e)
content = [""]
tkm.showerror(title="Fehler beim Öffnen",
message="Öffnen der Datei fehlgeschlagen.")
def clean(event=None):
global content_lines
global newcontent
newcontent = ""
t_preview.delete(0.0,tk.END)
for line in content_lines:
newline = re.sub(r"\s[(][a-zA-Zäöü\s]*[)]", "", line) # Fächer
newline = re.sub(r'["]', "", newline) # Anführungszeichen
tc = re.split(',', newline)
tc = [e.strip() for e in tc]
print(tc)
# Umsortieren
try:
tcnew = [tc[-1]] + [tc[1]] + [tc[0]] + tc[2:-1]
tcnew[-1] = tcnew[-1] + "\n"
except Exception as e:
print(e)
break
newline = ",".join(tcnew)
newcontent += newline
t_preview.insert(0.0,newcontent)
def save_file(event=None):
global fname
global newcontent
global out_encoding
if fname == "":
tkm.showerror(title="Fehler beim Speichern",
message="Speichern fehlgeschlagen")
return 1
fname_new = fname[:-4] + "c" + ".csv"
try:
f = open(fname_new, mode='w', encoding=out_encoding, errors='replace')
f.write(newcontent)
tkm.showinfo(title="Gespeichert",
message="Datei unter {} gespeichert.".format(fname_new))
except Exception as e:
print(e)
tkm.showerror(title="Fehler beim Speichern",
message="Speichern fehlgeschlagen")
bt_choose_file = tk.Button(root, text="Datei auswählen")
bt_choose_file.grid(row=0, column=0)
bt_choose_file["command"] = load_file
bt_clean = tk.Button(root, text="Bereinigen")
bt_clean.grid(row=0, column=1)
bt_clean["command"] = clean
bt_save_file = tk.Button(root, text="Speichern")
bt_save_file.grid(row=0, column=2)
bt_save_file["command"] = save_file
bt_quit = tk.Button(root, text="Beenden", fg="red")
bt_quit.grid(row=0, column=3)
bt_quit["command"] = root.destroy
t_preview = tk.Text(root, height = 15, width = 150)
t_preview.grid(row=1, column=0, columnspan=3, sticky="nwse")
root.mainloop()