-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathfiles.py
More file actions
51 lines (45 loc) · 1.7 KB
/
files.py
File metadata and controls
51 lines (45 loc) · 1.7 KB
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
from pathlib import Path
from tkinter import filedialog, messagebox
import pandas as pd
import tui
from version import __version__
def open_file(title="Select file",filetypes=None) -> str:
filetypes_final = filetypes.copy()
filetypes_final.append(("All files","*.*"))
file_path = filedialog.askopenfilename(title=title,filetypes=filetypes_final)
return file_path
def open_new_file(title="Save as...",extension=None) -> str:
return filedialog.asksaveasfilename(title=title,extension=extension)
def get_excel_filename(argv: list[str]) -> str:
try:
filename = argv[1]
except IndexError:
filename = ""
while not filename:
filename = open_file(filetypes=[("Excel files","*.xlsx *.xls")])
if not filename:
give_up = messagebox.askyesno("Quit?","No Excel file was selected. Abort?")
if give_up:
break
return filename
def parse_excel(filename: str="") -> pd.DataFrame:
try:
file = pd.ExcelFile(filename)
except FileNotFoundError:
messagebox.showerror(f"{filename} does not exist!")
return None
except ValueError as ve:
messagebox.showerror(f"There was an error parsing the Excel file '{filename}': {ve}")
return None
except Exception as e:
messagebox.showerror(f"An unexpected error occurred: {e}")
return None
try:
sheet_name = tui.choose_between(choices=file.sheet_names+["[Abort]"],ask="Which sheet to analyze?")
if sheet_name == "[Abort]":
return None
return file.parse(sheet_name=sheet_name)
finally:
file.close()
def read_text(filename: str):
return Path(filename).read_text()