Есть ли программное обеспечение, какое время - отслеживает окно и использование приложений?

Существует ли программное обеспечение, которое сохраняет время моих операций и дает отчет? На основе сфокусированного заголовка окна и заголовка окна. Отчет просто показал бы время, проведенное для определенного окна и его заголовка как:

Application   Title                             Time
Firefox       Ask Ubuntu - Mozilla Firefox      5:58
10
задан 2 June 2016 в 01:52

3 ответа


Править: версия сценария с отсортированными отчетами может быть найдена здесь


Всегда забава записать сценарий для него!

Сценарий ниже произведет вывод (отчет) как:

------------------------------------------------------------
nautilus
0:00:05 (3%)
------------------------------------------------------------
   0:00:05 (3%)     .usagelogs
------------------------------------------------------------
firefox
0:01:10 (36%)
------------------------------------------------------------
   0:00:05 (3%)     The Asker or the Answerer? - Ask Ubuntu Meta - Mozilla Firefox
   0:00:15 (8%)     scripts - Is there software which time- tracks window & application usage? - Ask Ubuntu - Mozilla Firefox
   0:00:10 (5%)     Ask Ubuntu - Mozilla Firefox
   0:00:15 (8%)     Why is a one line non-understandable answer used as review audit? - Ask Ubuntu Meta - Mozilla Firefox
   0:00:20 (10%)    bash - How to detect the number of opened terminals by the user - Ask Ubuntu - Mozilla Firefox
   0:00:05 (3%)     BlueGriffon - Mozilla Firefox
------------------------------------------------------------
gedit
0:02:00 (62%)
------------------------------------------------------------
   0:02:00 (62%)    2016_06_04_10_33_29.txt (~/.usagelogs) - gedit

============================================================
started: 2016-06-04 10:33:29    updated: 2016-06-04 10:36:46
============================================================


.. который обновляется однажды в минуту.

Примечания

  • Отчет возможно сообщит об окнах под категорией: "Неизвестный". Дело обстоит так, когда окна имеют pid 0 (tkinter окна, такой как Idle окна, aPython IDE). Об их заголовке окна и использовании сообщат правильно как бы то ни было.

  • Об экране блокировки с вводом пароля сообщают "nux входное окно".

  • Проценты являются округленными процентами, которые могли бы иногда приводить к незначительным различиям между процентом приложения и суммой процента его окна.

    Пример: Если приложение имеет два используемые окна, каждый используемый 0,7% из общего времени сообщат оба окна 1% каждый (0.7 -> округленный к 1), в то время как использование приложения сообщает 1% (1.4 -> округленный к 1)

    Никакая потребность сказать, что эти различия полностью не важны в целом изображении.

Сценарий

#!/usr/bin/env python3
import subprocess
import time
import os

# -- set update/round time (seconds)
period = 5
# -- 
# don change anything below
home = os.environ["HOME"]
logdir = home+"/.usagelogs"

def currtime(tformat=None):
    return time.strftime("%Y_%m_%d_%H_%M_%S") if tformat == "file"\
           else time.strftime("%Y-%m-%d %H:%M:%S")

try:
    os.mkdir(logdir)
except FileExistsError:
    pass

# path to your logfile
log = logdir+"/"+currtime("file")+".txt"; startt = currtime()

def get(command):
    try:
        return subprocess.check_output(command).decode("utf-8").strip()
    except subprocess.CalledProcessError:
        pass

def time_format(s):
    # convert time format from seconds to h:m:s
    m, s = divmod(s, 60); h, m = divmod(m, 60)
    return "%d:%02d:%02d" % (h, m, s)

def summarize():
    with open(log, "wt" ) as report:
        totaltime = sum([it[2] for it in winlist])
        report.write("")
        for app in applist:
            wins = [r for r in winlist if r[0] == app]
            apptime = sum([it[2] for it in winlist if it[0] == app])
            appperc = round(100*apptime/totaltime)
            report.write(("-"*60)+"\n"+app+"\n"+time_format(apptime)+\
                         " ("+str(appperc)+"%)\n"+("-"*60)+"\n")
            for w in wins:
                wperc = str(round(100*w[2]/totaltime))
                report.write("   "+time_format(w[2])+" ("+\
                             wperc+"%)"+(6-len(wperc))*" "+w[1]+"\n")
        report.write("\n"+"="*60+"\nstarted: "+startt+"\t"+\
                     "updated: "+currtime()+"\n"+"="*60)

t = 0; applist = []; winlist = []
while True:
    time.sleep(period)
    frpid = get(["xdotool", "getactivewindow", "getwindowpid"])
    frname = get(["xdotool", "getactivewindow", "getwindowname"])
    app = get(["ps", "-p", frpid, "-o", "comm="]) if frpid != None else "Unknown"
    # fix a few names
    if "gnome-terminal" in app:
        app = "gnome-terminal"
    elif app == "soffice.bin":
        app = "libreoffice"
    # add app to list
    if not app in applist:
        applist.append(app)
    checklist = [item[1] for item in winlist]
    if not frname in checklist:
        winlist.append([app, frname, 1*period])
    else:
        winlist[checklist.index(frname)][
            2] = winlist[checklist.index(frname)][2]+1*period
    if t == 60/period:
        summarize()
        t = 0
    else:
        t += 1

Как настроить

  1. Потребности сценария xdotool получить информацию окна

    sudo apt-get install xdotool
    
  2. Скопируйте сценарий в пустой файл, сохраните его как window_logs.py

  3. Тестовый прогон сценарий: пирог сценарий командой (от терминала):

    python3 /path/to/window_logs.py
    

    После одной минуты сценарий создает файл журнала с первыми результатами в ~/.usagelogs. Файл время - штампован с датой создания и время. Файл обновляется однажды в минуту.

    У основания файла Вы видите и время начала и метку времени последнего редактирования. Таким образом, можно всегда видеть то, что является отрезком времени файла.

    Если сценарий перезапускает, новый файл с новым (запустите-), метка времени создается.

  4. Если все хорошо работает, добавьте к Приложениям Запуска: Тире> Приложения Запуска> Добавляет. Добавьте команду:

    /bin/bash -c "sleep 15 && python3 /path/to/window_logs.py"
    

Больше примечаний

  • ~/.uselogs скрытый каталог по умолчанию. Нажмите (в nautilus) Ctrl+H для создания этого видимым.
  • Как это, сценарий округляет активность окна на 5 секундах, предполагая, что менее затем 5 секунд действительно не используют окно. Если требуется изменить значение, установите его в заголовке сценария в строке:

    # -- set update/round time (seconds)
    period = 5
    # -- 
    
  • Сценарий является чрезвычайно "низким на соке". Кроме того, так как время - обновляет на окно, сделаны в сценарии, количество строк в файле журнала ограничено фактическим количеством используемых окон.

    Тем не менее, я не запускал бы скрипт в течение многих недель подряд, например, для предотвращения накопления слишком многих строк (=window записи) для поддержания.

7
ответ дан 23 November 2019 в 04:33

существует arbtt это делает точно, что Вы описываете: https://www.joachim-breitner.de/blog/336-The_Automatic_Rule-Based_Time_Tracker

3
ответ дан 23 November 2019 в 04:33

Вот еще более простой скрипт, написанный на bash на основе xdotool, упомянутого в ответе Джейкоба Влейма.

while :
do
    sleep 1
    echo $(date +"%H:%M:%S") $(xdotool getactivewindow getwindowname) >> $datapath/log-$(date +"%Y-%m-%d").txt; 
done

Обязательно укажите, что такое $datapath. Сохраните файл как scrip.sh и запустите его в фоновом режиме:

./script.sh &

Удалите его из списка заданий, чтобы остановить. Или выведите его на передний план с помощью fg и используйте ctrl-c.

Если вы предпочитаете производить выборку с частотой менее 1 секунды, измените строку сна. Он сохраняет данные за каждый день в отдельном файле. Предполагая 300 байтов на строку, выборка с такой скоростью будет генерировать примерно 3600*24*300 = 25 МБ данных в день. Его можно легко сжать (при постобработке), так как заголовки многих окон повторяются.

Если вам нужны проценты использования, выполните awk для второго столбца и передайте его в uniq -c, а затем передайте в sort -nr. Это даст вам общее количество минут.

0
ответ дан 8 May 2020 в 17:45

Другие вопросы по тегам:

Похожие вопросы: