在Startup上运行Python脚本以记录Linux中的鼠标和键盘活动

时间:2017-05-10 19:41:59

标签: python linux cron keyboard

在问这个问题或者至少是一个类似的问题之前,我对很多人很有信心。我的问题有点问题,但很简单。

我试图在启动时使用cron运行Python脚本,并在Linux中编辑etc / rc.local文件,但两种方式都无法运行我的Python脚本。

我的脚本使用键盘和鼠标的侦听器对象记录键盘和鼠标的活动。我使用名为pynput的第三方软件包,该软件包依赖于Xlib。我的脚本编辑了一个需要sudo访问权限的文件,因此我必须使用sudo运行我的脚本。

您需要查看脚本,因此您知道:

#!/usr/bin/env python
#backlight.py

from pynput.keyboard import Listener  as KeyboardListener
from pynput.mouse    import Listener  as MouseListener

import time

STATUS = ""                # Keyboard backlight ON/OFF status
turnOffSecs = 6           # Turn off keyboard backlight for x seconds of inactivity

# Keyboard brightness control file (change to your directory)
file_pth = "/sys/devices/platform/asus-nb-wmi/leds/asus::kbd_backlight/brightness"

def get_LEVEL():
    """return the current level of brightness of keyboard backlight"""
    with open(file_pth, "r") as f:
        brightness_level = f.read()[0]
    return brightness_level


class Sec_timer:
    """
    Sec_timer(until=None) 
        Create a timer that counts x number of seconds starting from 0

        until arg can be used for reseting the timer:

   *Example:

        timer = Sec_imer(20)
        while timer.elapsed < timer.until:                  
            timer.count()                # count a second
        else:
            timer.reset_timer()          # reset timer on exit
    """
    def __init__(self, until=None):
        self.until = until
        self.elapsed = 0 

    def count_sec(self): 
        "Count one second per-call"
        time.sleep(1)
        self.elapsed += 1

    def reset_timer(self):
        self.elapsed = 0 



timer = Sec_timer(turnOffSecs)           # Sec_timer(x) turn off keyboard backlight for x seconds of inactivity

# General event handler to reset timer
def reset_timer(*args):
    global STATUS

    timer.reset_timer()
    if STATUS == "OFF":
         # print(STATUS)
         with open(file_pth, "w") as f:
             f.write(current_brightnessLevel)
             f.close()
             STATUS="ON"



keyboard_listener = KeyboardListener(on_press=reset_timer, 
                             on_release=(lambda *args: None))

mouse_listener    = MouseListener(on_click=reset_timer, 
                             on_scroll=reset_timer, 
                             on_move=reset_timer)


keyboard_listener.start()
mouse_listener.start()


while True:
    timer.count_sec()
    if timer.elapsed > timer.until:
        # print "current brightness:" +  get_LEVEL()
        if  get_LEVEL() != "0":
            with open(file_pth, "w") as f: 
                current_brightnessLevel = get_LEVEL()
                f.write("0")
                STATUS = "OFF"

此脚本记录键盘和鼠标的活动,任何键盘或鼠标活动都将重置计时器。当x秒过去且没有发生键盘或鼠标活动时,通过将“0”写入亮度文件夹来关闭键盘的背光。如果发生任何鼠标或键盘事件after脚本关闭了背光,则根据背光的先前亮度级别打开键盘亮度。

使用终端运行脚本,它完全正常。但是,自动启动此脚本非常棘手;这是我到目前为止所做的:

*注意,我已将脚本文件设为可执行文件,backlight.py位于/home/user

1)在终端:

$ xhost +
$ sudo ./backlight.py

工作正常!

2)使用`etc / rc.local我添加了:

xhost + 
cd /home/user/
./backlight.py

重启后脚本没有运行

3)使用etc/rc.local

$ sudo crontab -e

@reboot xhost +
@reboot /home/user/backlight.py

重启后没有运行

由于xhost +存在问题,我必须执行Xlib。使用最后两种方法不起作用。我猜这是一个编程问题,也许它与Xlib有关?!

我知道这个脚本在与键盘LED接口方面是疯狂的,如果你愿意,可以称之为“坏脚本”。虽然我只是试图使用文件输入/输出解决方案解决驱动程序问题,因为我没有兴趣深入研究Linux驱动程序的详细信息,至少现在不是这样!

1 个答案:

答案 0 :(得分:0)

如果它需要root并且必须在启动时运行,为什么不创建自定义服务?

如果您说创建自定义服务,systemd可以为您启动它。 然后,您可以使用sudo systemctl start yourservice启动服务 并且您可以确保它在sudo systemctl enable yourservice启动时(以root用户身份)运行。无论用户如何,它都会启动。

我以前没有亲自做过这件事,但这不应该太困难。它基本上只是一个包含描述和执行命令的文件,在/ etc / systemd / system目录中创建。一个快速的谷歌搜索给了我这个指南:https://blog.sdbarker.com/post/adding-custom-units-services-to-systemd-on-arch-linux/

希望有所帮助。