2018-09-27 20:24:09 +00:00
|
|
|
#!/usr/bin/env python
|
2018-09-24 22:01:00 +00:00
|
|
|
import sys
|
2018-10-15 20:07:23 +00:00
|
|
|
|
2018-09-28 18:57:37 +00:00
|
|
|
if sys.version_info[0] >= 3:
|
2018-09-27 20:24:09 +00:00
|
|
|
import PySimpleGUI as sg
|
2018-09-28 18:57:37 +00:00
|
|
|
else:
|
|
|
|
import PySimpleGUI27 as sg
|
2018-09-27 20:24:09 +00:00
|
|
|
import csv
|
|
|
|
|
2018-09-13 16:13:27 +00:00
|
|
|
|
2018-09-20 14:41:47 +00:00
|
|
|
filename = sg.PopupGetFile('filename to open', no_window=True, file_types=(("CSV Files","*.csv"),))
|
2018-09-13 16:13:27 +00:00
|
|
|
# --- populate table with file contents --- #
|
|
|
|
data = []
|
|
|
|
if filename is not None:
|
|
|
|
with open(filename, "r") as infile:
|
|
|
|
reader = csv.reader(infile)
|
|
|
|
try:
|
|
|
|
data = list(reader) # read everything else into a list of rows
|
|
|
|
except:
|
|
|
|
sg.PopupError('Error reading file')
|
2018-09-24 22:01:00 +00:00
|
|
|
sys.exit(69)
|
2018-10-29 00:01:03 +00:00
|
|
|
else:
|
|
|
|
sys.exit()
|
2018-09-13 16:13:27 +00:00
|
|
|
|
2018-10-29 00:01:03 +00:00
|
|
|
# sg.SetOptions(element_padding=(0,0))
|
2018-10-15 20:07:23 +00:00
|
|
|
headings = [data[0][x] for x in range(len(data[0]))]
|
|
|
|
|
2018-10-29 00:01:03 +00:00
|
|
|
layout = [[sg.Table(values=data[1:][:], headings=headings, max_col_width=25,
|
|
|
|
auto_size_columns=True, display_row_numbers=True, justification='right', num_rows=20, alternating_row_color='lightblue', key='_table_')],
|
|
|
|
[sg.Button('Read'), sg.Button('Double')],
|
|
|
|
[sg.T('Read = read which rows are selected')],[sg.T('Double = double the amount of data in the table')]]
|
|
|
|
|
|
|
|
window = sg.Window('Table', grab_anywhere=False, resizable=True).Layout(layout)
|
|
|
|
|
|
|
|
while True:
|
|
|
|
event, values = window.Read()
|
|
|
|
if event is None:
|
|
|
|
break
|
|
|
|
if event == 'Double':
|
|
|
|
for i in range(len(data)):
|
|
|
|
data.append(data[i])
|
|
|
|
window.FindElement('_table_').Update(values = data)
|
|
|
|
sg.Popup(event, values)
|
|
|
|
# print(event, values)
|
2018-09-18 16:05:44 +00:00
|
|
|
|
2018-09-24 22:01:00 +00:00
|
|
|
sys.exit(69)
|