-
Notifications
You must be signed in to change notification settings - Fork 0
/
window_sensor.py
56 lines (49 loc) · 2.21 KB
/
window_sensor.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
import sys
from AppKit import NSWorkspace
import time
from datetime import datetime
class WindowSensor(object):
front_most_app = ""
seconds = 0
iterations = 0
interval_seconds = 0
path_to_write = ""
def __init__(self, days, interval_seconds, path_to_write):
self.seconds = days * 24 * 60 * 60
self.interval_seconds = interval_seconds
self.iterations = self.seconds / self.interval_seconds
self.front_most_app = self.getFrontMostApplication()
self.path_to_write = path_to_write
def getFrontMostApplication(self):
'''
sample out put of NSWorkspace.sharedWorkspace().activeApplication()
{
NSApplicationBundleIdentifier = "com.microsoft.VSCode";
NSApplicationName = Code;
NSApplicationPath = "/Applications/Visual Studio Code.app";
NSApplicationProcessIdentifier = 384;
NSApplicationProcessSerialNumberHigh = 0;
NSApplicationProcessSerialNumberLow = 114716;
NSWorkspaceApplicationKey = "<NSRunningApplication: 0x7feb92594fb0 (com.microsoft.VSCode - 384)>";
}
'''
return NSWorkspace.sharedWorkspace().activeApplication()["NSApplicationName"]
def getTime(self):
return datetime.now().strftime('%Y-%m-%d %H:%M:%S')
def monitor(self):
for i in range(self.iterations):
time.sleep(self.interval_seconds)
cur_time = self.getTime()
cur_front_most_app = self.getFrontMostApplication()
if cur_front_most_app != self.front_most_app:
topped = (cur_time, "window", "top", cur_front_most_app)
left = (cur_time, "window", "leave", self.front_most_app)
self.front_most_app = cur_front_most_app
with open(self.path_to_write, 'a') as log_file:
log_file.write('{}, {}, {}, {}'.format(topped[0], topped[1], topped[2], topped[3]))
log_file.write('\n')
log_file.write('{}, {}, {}, {}'.format(left[0], left[1], left[2], left[3]))
log_file.write('\n')
if __name__ == "__main__":
ws = WindowSensor(4, 10, "stranger2_window_log.txt")
ws.monitor()