Removed f-strings, fixed Raspberry Pi launching issue. New function names for ReadNonBlocking - Finalize, PreRead

This commit is contained in:
MikeTheWatchGuy 2018-09-13 19:57:58 -04:00
parent a74ec9bdae
commit f112907e89
3 changed files with 17 additions and 10 deletions

View File

@ -16,8 +16,8 @@ ROOT_PATH = './'
def Launcher(): def Launcher():
def print(line): # def print(line):
form.FindElement('output').Update(line) # form.FindElement('output').Update(line)
sg.ChangeLookAndFeel('Dark') sg.ChangeLookAndFeel('Dark')
@ -56,11 +56,15 @@ def ExecuteCommandSubprocess(command, *args, wait=False):
try: try:
if sys.platform == 'linux': if sys.platform == 'linux':
arg_string = '' arg_string = ''
for arg in args: arg_string = ' '.join([str(arg) for arg in args])
arg_string += ' ' + str(arg) # for arg in args:
sp = subprocess.Popen(['python3' + arg_string, ], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE) # arg_string += ' ' + str(arg)
print('python3 ' + arg_string)
sp = subprocess.Popen(['python3 ', arg_string ], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
else: else:
sp = subprocess.Popen([command, list(args)], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE) arg_string = ' '.join([str(arg) for arg in args])
sp = subprocess.Popen([command, arg_string], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
# sp = subprocess.Popen([command, list(args)], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
if wait: if wait:
out, err = sp.communicate() out, err = sp.communicate()

View File

@ -19,7 +19,7 @@ sg.ChangeLookAndFeel('Black')
form_rows = [[sg.Text('', size=(8,1), font=('Helvetica', 20),text_color=sg.YELLOWS[0], justification='center', key='text')], form_rows = [[sg.Text('', size=(8,1), font=('Helvetica', 20),text_color=sg.YELLOWS[0], justification='center', key='text')],
[sg.Text('', size=(30, 8), font=('Courier', 10),text_color='white', justification='left', key='processes')], [sg.Text('', size=(30, 8), font=('Courier', 10),text_color='white', justification='left', key='processes')],
[sg.Exit(button_color=('white', 'firebrick4'), pad=((15,0), 0)), sg.Spin([x+1 for x in range(10)], 1, key='spin')]] [sg.Exit(button_color=('white', 'firebrick4'), pad=((15,0), 0)), sg.Spin([x+1 for x in range(10)], 1, key='spin')]]
# Layout the rows of the form and perform a read. Indicate the form is non-blocking!
form = sg.FlexForm('Running Timer', no_titlebar=True, auto_size_buttons=False, keep_on_top=True, grab_anywhere=True) form = sg.FlexForm('Running Timer', no_titlebar=True, auto_size_buttons=False, keep_on_top=True, grab_anywhere=True)
form.Layout(form_rows) form.Layout(form_rows)
@ -38,16 +38,17 @@ while (True):
cpu_percent = psutil.cpu_percent(interval=interval) cpu_percent = psutil.cpu_percent(interval=interval)
# --------- Create list of top % CPU porocesses --------
top = {proc.name() : proc.cpu_percent() for proc in psutil.process_iter()} top = {proc.name() : proc.cpu_percent() for proc in psutil.process_iter()}
top_sorted = sorted(top.items(), key=operator.itemgetter(1), reverse=True) top_sorted = sorted(top.items(), key=operator.itemgetter(1), reverse=True)
top_sorted.pop(0) top_sorted.pop(0)
display_string = '' display_string = ''
for proc, cpu in top_sorted: for proc, cpu in top_sorted:
display_string += f'{cpu:2.0f} {proc}\n' display_string += '{} {}\n'.format(cpu, proc)
# --------- Display timer in window --------
form.FindElement('text').Update(f'CPU {cpu_percent:02.0f}%') # --------- Display timer in window --------
form.FindElement('text').Update('CPU {}'.format(cpu_percent))
# form.FindElement('processes').Update('\n'.join(top_sorted)) # form.FindElement('processes').Update('\n'.join(top_sorted))
form.FindElement('processes').Update(display_string) form.FindElement('processes').Update(display_string)

View File

@ -1749,6 +1749,8 @@ class FlexForm:
# Another name for ReadNonBlocking. # Another name for ReadNonBlocking.
PrepareForUpdate = ReadNonBlocking PrepareForUpdate = ReadNonBlocking
Finalize = ReadNonBlocking
PreRead = ReadNonBlocking
def Refresh(self): def Refresh(self):