Python 程序不完全执行,停止在中间

Python 程序不完全执行,停止在中间,python,dictionary,service,Python,Dictionary,Service,我得到了输出: ankit@ubuntu:~/Desktop$python controlpt.py from brisa.core.reactors import install_default_reactor reactor = install_default_reactor() print reactor from brisa.core.threaded_call import run_async_function from brisa.upnp.control_point.cont

我得到了输出:

ankit@ubuntu:~/Desktop$python controlpt.py

from brisa.core.reactors import install_default_reactor

reactor = install_default_reactor()
print reactor

from brisa.core.threaded_call import run_async_function

from brisa.upnp.control_point.control_point import ControlPoint

from datetime import datetime

service = ('u', 'urn:schemas-upnp-org:service:SwitchPower:1')

binary_light_type = 'urn:schemas-upnp-org:device:BinaryLight:1'

def on_new_device(dev):

    print 'Got new device:', dev.udn

    print "Type 'list' to see the whole list"

    if not dev:
            return

def get_switch_service(device):

    return device.services[service[1]]

def create_control_point():

    c = ControlPoint()

    print "hello"   

    c.subscribe('new_device_event', on_new_device)  

    print "c"

    return c

def main():

    """ Main loop iteration receiving input commands.

    """

    print "hell"

    c = create_control_point()
    print "helllo"

    c.start()

    run_async_function(_handle_cmds, (c, ))

    reactor.add_after_stop_func(c.stop)

    reactor.main()

def _exit(c):

    """ Stops the _handle_cmds loop

    """

    global running_handle_cmds

    running_handle_cmds = False

def _search(c):

    """ Start searching for devices of type upnp:rootdevice and repeat

    search every 600 seconds (UPnP default)

    """

    c.start_search(600, 'upnp:rootdevice')


def _get_status(c):

    """ Gets the binary light status and print if it's on or off.

    """

    try:

        service = get_switch_service(c.current_server)

        status_response = service.GetStatus()

        if status_response['ResultStatus'] == '1':

            print 'Binary light status is on'

        else:

            print 'Binary light status is off'

    except Exception, e:

        if not hasattr(c, 'current_server') or not c.current_server:

            print 'BinaryLight device not set.Please use set_light <n>'

        else:

            print 'Error in get_status():', e

def _get_target(c):

    """ Gets the binary light target and print if it's on or off.

    """

    try:

        service = get_switch_service(c.current_server)

        status_response = service.GetTarget()

        if status_response['RetTargetValue'] == '1':

            print 'Binary light target is on'

        else:

            print 'Binary light target is off'

    except Exception, e:

        if not hasattr(c, 'current_server') or not c.current_server:

            print 'BinaryLight device not set.Please use set_light <n>'

        else:

            print 'Error in get_target():', e

def _stop(c):

    """ Stop searching

    """

    c.stop_search()

def _list_devices(c):

    """ Lists the devices that are in network.

    """

    k = 0

    for d in c.get_devices().values():

        print 'Device no.:', k

        print 'UDN:', d.udn

        print 'Name:', d.friendly_name

        print 'Device type:', d.device_type

        print 'Services:', d.services.keys() # Only print services name

        print

        k += 1

if __name__ == '__main__':
    print "hello"

    main()

它不会到达线c=创建控制点。为什么呢?请指导我删除此错误。

我不熟悉此“brisa”库。我认为,出于某种原因,ControlPoint构造函数正在使用sys.exit退出整个程序,或者正在调用一些等效的C代码

在命令行上运行程序,如下所示:

<brisa.core.reactors.glib2.GLib2Reactor object at 0x88c3e0c>
hello
hell

然后你应该能够看到它是否真的放弃了整个过程。如果它将您转储回>>>提示符,那么我不知道发生了什么。但是如果它完全退出Python,这意味着ControlPoint构造函数正在退出。

我建议您打印更多有用的注释,例如完成的create\u control\u point和内部的create\u control\u point,而不是使用不同数量的ls在Hello上的不同变体。是的……您说得对,ControlPoint构造函数正在退出。我该如何纠正它?你可以在这里看到布里萨图书馆:请给我提建议。我简单地看了一下那些文件。除了ControlPoint构造函数使用大量代码调用许多其他构造函数之外,没有任何明显的东西浮现在脑海中。任何一个都可能是原因。我会寻找对C代码的调用;这很可能是退出——也许某些C代码在出现错误的情况下退出,而不是引发适当的Python异常。
$ python
>>> import controlpt
>>> controlpt.main()