我正在发现python的signal
模块,我为第一次实现编写了这个脚本:
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
""" First implementation of signal module """
import time
import signal
import os
import sys
def cls():
""" console clearing """
os.system('clear')
return
def handler(signal, frame):
""" Catch <ctrl+c> signal for clean stop"""
print("{}, script stops".format(time.strftime('%H:%M:%S')))
sys.exit(0)
signal.signal(signal.SIGINT, handler)
START_TIME = time.strftime('%H:%M:%S')
PROGRESSION = str()
while True:
time.sleep(2)
PROGRESSION += "."
cls()
print("{}, script starts\n{}".format(START_TIME, PROGRESSION))
除了中断后出现的令人讨厌的^C
字符串外,脚本按预期工作:
14:38:01, script starts
......
^C14:38:14, script stops
然而,pylint3
检查给了我这个回报:
testsignal.py:16: [W0621(redefined-outer-name), handler] Redefining name 'signal' from outer scope (line 5)
testsignal.py:16: [W0613(unused-argument), handler] Unused argument 'signal'
testsignal.py:16: [W0613(unused-argument), handler] Unused argument 'frame'
根据signal documentation,我做对了。
如果我更改第16行,signal
参数中有一个尾随下划线(如PEP8中所述,我解决警告 W0621 。
是pylint
的副作用还是我错过了什么?
顺便说一句,如果有人知道如何避免^C
字符串,我也会很高兴。
pylint3 --version
pylint3 1.5.2,
astroid 1.4.4
Python 3.4.2 (default, Oct 8 2014, 10:45:20)
[GCC 4.9.1]
答案 0 :(得分:1)
pylint警告你,你有一个函数有两个参数,你没有在函数内部使用,这是真的,并且是常见错误的气味。
它还警告使用等于外部作用域名称的本地函数名称,这有时会导致错误,因为您可能无意中隐藏了外部名称。有时你是故意这样做的,所以pylint只是惹恼了一下,但你也可以像你一样重命名当地人并摆脱危险。
这些只是警告而不是错误。通常,即使它们不存在,也要对可能出现的问题进行警告。
静态检查器不知道信号库如何调用您的处理程序。但警告并没有与此有关。静态工具刚刚注意到您声称接收到两个参数,但您没有在处理程序主体中使用它们。通常当您收到参数时,您想要使用它吗?除非您在库中注册处理程序以进行回调,否则您必须尊重库&#34; protocol&#34;,否则当从那里完成回调时,您将收到运行时错误。静态工具不知道你不关心收到的信号信息,只是打印其他东西;它只是对你说:那看起来很奇怪,你确定吗?