使用没有pylint警告的信号模块(W0621& W0613)

时间:2018-02-22 14:21:39

标签: python signals pylint

我正在发现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]

1 个答案:

答案 0 :(得分:1)

pylint警告你,你有一个函数有两个参数,你没有在函数内部使用,这是真的,并且是常见错误的气味。

它还警告使用等于外部作用域名称的本地函数名称,这有时会导致错误,因为您可能无意中隐藏了外部名称。有时你是故意这样做的,所以pylint只是惹恼了一下,但你也可以像你一样重命名当地人并摆脱危险。

这些只是警告而不是错误。通常,即使它们不存在,也要对可能出现的问题进行警告。

静态检查器不知道信号库如何调用您的处理程序。但警告并没有与此有关。静态工具刚刚注意到您声称接收到两个参数,但您没有在处理程序主体中使用它们。通常当您收到参数时,您想要使用它吗?除非您在库中注册处理程序以进行回调,否则您必须尊重库&#34; protocol&#34;,否则当从那里完成回调时,您将收到运行时错误。静态工具不知道你不关心收到的信号信息,只是打印其他东西;它只是对你说:那看起来很奇怪,你确定吗?