import PySimpleGUI as sg """ Demo - User Settings Use the "user_settings" API calls to make a "settings window" This demo is very basic. The user_settings functions are used directly without a lookup table or some other mechanism to map between PySimpleGUI keys and user settings keys. Two windows are shown. One is a super-simple "save previously entered filename" The other is a larger "settings window" where multiple settings are saved/loaded Copyright 2020 PySimpleGUI.org """ SETTINGS_PATH = '.' def make_window(): """ Creates a new window. The default values for some elements are pulled directly from the "User Settings" without the use of temp variables. Some get_entry calls don't have a default value, such as theme, because there was an initial call that would have set the default value if the setting wasn't present. Could still put the default value if you wanted but it would be 2 places to change if you wanted a different default value. Use of a lookup table to map between element keys and user settings could be aded. This demo is intentionally done without one to show how to use the settings APIs in the most basic, straightforward way. If your application allows changing the theme, then a make_window function is good to have so that you can close and re-create a window easily. :return: (sg.Window) The window that was created """ sg.theme(sg.user_settings_get_entry('theme', 'DarkBlue2')) # set the theme layout = [[sg.Text('Settings Window')], [sg.Input(sg.user_settings_get_entry('input', ''), k='-IN-')], [sg.Listbox(sg.theme_list(), default_values=[sg.user_settings_get_entry('theme')], size=(15, 10), k='-LISTBOX-')], [sg.CB('Option 1', sg.user_settings_get_entry('option1', True), k='-CB1-')], [sg.CB('Option 2', sg.user_settings_get_entry('option2', False), k='-CB2-')], [sg.T('Settings file = ' + sg.user_settings_filename())], [sg.Button('Save'), sg.Button('Exit without saving', k='Exit')]] return sg.Window('A Settings Window', layout) def settings_window(): """ Create and interact with a "settings window". You can a similar pair of functions to your code to add a "settings" feature. """ window = make_window() current_theme = sg.theme() while True: event, values = window.read() if event in (sg.WINDOW_CLOSED, 'Exit'): break if event == 'Save': # Save some of the values as user settings sg.user_settings_set_entry('input', values['-IN-']) sg.user_settings_set_entry('theme', values['-LISTBOX-'][0]) sg.user_settings_set_entry('option1', values['-CB1-']) sg.user_settings_set_entry('option2', values['-CB2-']) # if the theme was changed, restart the window if values['-LISTBOX-'][0] != current_theme: current_theme = values['-LISTBOX-'][0] window.close() window = make_window() def save_previous_filename_demo(): """ Saving the previously selected filename.... A 2-line demo of one of the likely most popular use of user settings * Get the previously entered filename * Use previous as default for Input * When a new filename is chosen, write the filename to user settings """ prior_filename = sg.user_settings_get_entry('filename', '') layout = [[sg.Text('Enter a filename:')], [sg.Input(prior_filename, key='-IN-'), sg.FileBrowse()], [sg.B('OK')]] event, values = sg.Window('Filename Example', layout).read(close=True) # If user clicked OK, then save the filename for next time if event == 'OK': sg.user_settings_set_entry('filename', values['-IN-']) if __name__ == '__main__': sg.user_settings_filename(path=SETTINGS_PATH) # Set the location for the settings file # Run a couple of demo windows save_previous_filename_demo() settings_window()