O script a seguir lista todos os processos e os divide em aplicativos e outros processos .
Como definição para um aplicativo, eu pratico que o processo é iniciado a partir de um arquivo .desktop
(já que praticamente todos os aplicativos são representados por um arquivo .desktop
) e que o arquivo .desktop
aparece no Dash o arquivo.desktop
não possui linha: NoDisplay=true
).
Trabalho a ser feito:
O script, como é, deriva o nome do processo do aplicativo da (última seção de-) o comando, encontrado no arquivo da área de trabalho, e também das informações encontradas nos possíveis links simbólicos aos quais ele pode se referir de LibreOffice
> nome do processo: soffice.bin
). Em alguns casos, no entanto, um aplicativo é executado a partir de um script remoto, chamado a partir do arquivo .desktop
. Nesses casos, o processo não será reconhecido como um aplicativo.
O script fornece uma saída como:
Processes, related to applications:
PID TTY TIME CMD
1933 ? 00:03:55 firefox
18091 ? 00:00:00 dia
18162 ? 00:00:01 soffice.bin
31167 ? 00:00:06 alarm-clock-app
31174 ? 00:00:09 nautilus
31301 ? 00:00:20 dropbox
31998 ? 00:01:35 idle3
Other processes:
PID TTY TIME CMD
1 ? 00:00:01 init
2 ? 00:00:00 kthreadd
3 ? 00:00:02 ksoftirqd/0
5 ? 00:00:00 kworker/0:0H
7 ? 00:00:15 rcu_sched
8 ? 00:00:08 rcuos/0
etc ...
O script
#!/usr/bin/env python3
import os
import subprocess
def createlist_appcommands():
dtfile_dir = "/usr/share/applications"
dtfile_list = [item for item in os.listdir(dtfile_dir) if item.endswith(".desktop")]
commands = []
for item in dtfile_list:
try:
with open(dtfile_dir+"/"+item) as data:
searchlines = data.readlines()
command = [line for line in searchlines if line.startswith("Exec=")
and not "NoDisplay=true\n" in searchlines
][0].replace("Exec=", "").replace("\n", "").split("/")[-1].split(" ")[0]
commands.append(command)
except Exception:
pass
return commands + [trace_symlinks(item) for item in commands if not trace_symlinks(item)== None]
def trace_symlinks(command):
target = subprocess.Popen(["which", command], stdout=subprocess.PIPE)
location = (target.communicate()[0].decode("utf-8")).split("\n")[0]
check_filetype = subprocess.Popen(["file", location], stdout=subprocess.PIPE)
filetype = (check_filetype.communicate()[0].decode("utf-8")).split("\n")[0]
if "symbolic link" in filetype:
return filetype.split("/")[-1].replace("' ", "")
else:
pass
def createlist_runningprocs():
processesb = subprocess.Popen(["ps", "-e"], stdout=subprocess.PIPE)
process_listb = (processesb.communicate()[0].decode("utf-8")).split("\n")
linked_commands = [(item, item[24:]) for item in process_listb][1:]
applist = createlist_appcommands()
print("Processes, related to applications:\n PID TTY"+" "*10+"TIME CMD")
matches = []
for item in applist:
for i in range(0, len(linked_commands)):
if item[:15] in linked_commands[i][1] and len(item[:15])/len(linked_commands[i][1]) > 0.5:
matches.append(i)
matches = sorted(matches)
for i in range(0, len(linked_commands)):
if i in matches:
print(linked_commands[i][0])
print("\nOther processes:\n PID TTY"+" "*10+"TIME CMD")
for i in range(0, len(linked_commands)):
if not i in matches:
print(linked_commands[i][0])
createlist_runningprocs()
Como usar
Copie o script em um arquivo vazio, salve-o como processes.py
, execute-o pelo comando:
python3 /path/to/processes.py
Editar: atualizei minha resposta, reescrevi o script.
Melhorias:
-
(muito) melhor desempenho
-
o script agora rastreia e reconhece aplicativos, iniciados por meio de links simbólicos (que podem ter outro nome de processo). Embora as exceções sejam sempre possíveis, elas devem ser raras agora.