From 9c1ebeb0b4d3bb2a41c6f20adf06eeb2f77b45d6 Mon Sep 17 00:00:00 2001 From: MikeTheWatchGuy Date: Thu, 9 Aug 2018 11:37:44 -0400 Subject: [PATCH] Removed need to flag a form as one returning a dictionary --- Demo_Dictionary.py | 13 +++++++---- PySimpleGUI.py | 54 +++++++++++++++++++++++++++++++--------------- 2 files changed, 46 insertions(+), 21 deletions(-) diff --git a/Demo_Dictionary.py b/Demo_Dictionary.py index c1a060da..9b001eae 100644 --- a/Demo_Dictionary.py +++ b/Demo_Dictionary.py @@ -2,14 +2,19 @@ import PySimpleGUI as sg # THIS FILE REQIRES THE LATEST PySimpleGUI.py FILE # IT WILL NOT WORK WITH CURRENT PIP RELEASE (2.7) +# +# If you want to use the return values as Dictionary feature, you need to download the PySimpleGUI.py file +# from GitHub and then place it in your project's folder. This SHOULD cause it to use this downloaded version +# instead of the pip installed one, if you've pip installed it. You can always uninstall the pip one :-) -# Shows how to use return values in dictionary form -form = sg.FlexForm('Simple data entry form', use_dictionary=True) # begin with a blank form +# This design pattern shows how to use return values in dictionary form + +form = sg.FlexForm('Simple data entry form') # begin with a blank form layout = [ [sg.Text('Please enter your Name, Address, Phone')], - [sg.Text('Name', size=(15, 1)), sg.InputText('1', key='name')], + [sg.Text('Name', size=(15, 1)), sg.InputText('1')], [sg.Text('Address', size=(15, 1)), sg.InputText('2', key='address')], [sg.Text('Phone', size=(15, 1)), sg.InputText('3', key='phone')], [sg.Submit(), sg.Cancel()] @@ -17,6 +22,6 @@ layout = [ button, values = form.LayoutAndRead(layout) -sg.MsgBox(button, values, values['name'], values['address'], values['phone']) +sg.MsgBox(button, values, values[0], values['address'], values['phone']) print(values) diff --git a/PySimpleGUI.py b/PySimpleGUI.py index c75a160f..07bbc3af 100644 --- a/PySimpleGUI.py +++ b/PySimpleGUI.py @@ -774,7 +774,7 @@ class FlexForm: ''' Display a user defined for and return the filled in data ''' - def __init__(self, title, default_element_size=(DEFAULT_ELEMENT_SIZE[0], DEFAULT_ELEMENT_SIZE[1]), auto_size_text=None, auto_size_buttons=None, scale=(None, None), location=(None, None), button_color=None, font=None, progress_bar_color=(None, None), background_color=None, is_tabbed_form=False, border_depth=None, auto_close=False, auto_close_duration=DEFAULT_AUTOCLOSE_TIME, icon=DEFAULT_WINDOW_ICON, use_dictionary=False): + def __init__(self, title, default_element_size=(DEFAULT_ELEMENT_SIZE[0], DEFAULT_ELEMENT_SIZE[1]), auto_size_text=None, auto_size_buttons=None, scale=(None, None), location=(None, None), button_color=None, font=None, progress_bar_color=(None, None), background_color=None, is_tabbed_form=False, border_depth=None, auto_close=False, auto_close_duration=DEFAULT_AUTOCLOSE_TIME, icon=DEFAULT_WINDOW_ICON): self.AutoSizeText = auto_size_text if auto_size_text is not None else DEFAULT_AUTOSIZE_TEXT self.AutoSizeButtons = auto_size_buttons if auto_size_buttons is not None else DEFAULT_AUTOSIZE_BUTTONS self.Title = title @@ -803,7 +803,7 @@ class FlexForm: self.ReturnValues = None self.ReturnValuesDictionary = None self.ResultsBuilt = False - self.UseDictionary = use_dictionary + self.UseDictionary = False self.UseDefaultFocus = False # ------------------------- Add ONE Row to Form ------------------------- # @@ -853,9 +853,14 @@ class FlexForm: try: if element.Focus: found_focus = True - break except: pass + try: + if element.Key is not None: + self.UseDictionary = True + except: + pass + if not found_focus: self.UseDefaultFocus = True # -=-=-=-=-=-=-=-=- RUN the GUI -=-=-=-=-=-=-=-=- ## @@ -1145,6 +1150,7 @@ def BuildResults(form): button_pressed_text = None input_values = [] input_values_dictionary = {} + key_counter = 0 for row_num,row in enumerate(form.Rows): for col_num, element in enumerate(row): if element.Type == ELEM_TYPE_INPUT_TEXT: @@ -1153,25 +1159,31 @@ def BuildResults(form): input_values.append(value) if not form.NonBlocking: element.TKStringVar.set('') - try: + if element.Key is None: + input_values_dictionary[key_counter] = value + key_counter +=1 + else: input_values_dictionary[element.Key] = value - except: pass elif element.Type == ELEM_TYPE_INPUT_CHECKBOX: value=element.TKIntVar.get() results[row_num][col_num] = value input_values.append(value != 0) - try: + if element.Key is None: + input_values_dictionary[key_counter] = value + key_counter +=1 + else: input_values_dictionary[element.Key] = value - except: pass elif element.Type == ELEM_TYPE_INPUT_RADIO: RadVar=element.TKIntVar.get() this_rowcol = EncodeRadioRowCol(row_num,col_num) value = RadVar == this_rowcol results[row_num][col_num] = value input_values.append(value) - try: + if element.Key is None: + input_values_dictionary[key_counter] = value + key_counter +=1 + else: input_values_dictionary[element.Key] = value - except: pass elif element.Type == ELEM_TYPE_BUTTON: if results[row_num][col_num] is True: button_pressed_text = element.ButtonText @@ -1181,17 +1193,21 @@ def BuildResults(form): value=element.TKStringVar.get() results[row_num][col_num] = value input_values.append(value) - try: + if element.Key is None: + input_values_dictionary[key_counter] = value + key_counter +=1 + else: input_values_dictionary[element.Key] = value - except: pass elif element.Type == ELEM_TYPE_INPUT_LISTBOX: items=element.TKListbox.curselection() value = [element.Values[int(item)] for item in items] results[row_num][col_num] = value input_values.append(value) - try: + if element.Key is None: + input_values_dictionary[key_counter] = value + key_counter +=1 + else: input_values_dictionary[element.Key] = value - except: pass elif element.Type == ELEM_TYPE_INPUT_SPIN: try: value=element.TKStringVar.get() @@ -1199,9 +1215,11 @@ def BuildResults(form): value = 0 results[row_num][col_num] = value input_values.append(value) - try: + if element.Key is None: + input_values_dictionary[key_counter] = value + key_counter +=1 + else: input_values_dictionary[element.Key] = value - except: pass elif element.Type == ELEM_TYPE_INPUT_SLIDER: try: value=element.TKIntVar.get() @@ -1221,9 +1239,11 @@ def BuildResults(form): value = None results[row_num][col_num] = value input_values.append(value) - try: + if element.Key is None: + input_values_dictionary[key_counter] = value + key_counter +=1 + else: input_values_dictionary[element.Key] = value - except: pass try: input_values_dictionary.pop(None, None) # clean up dictionary include None was included