Python 程序不完全执行,停止在中间
我得到了输出: ankit@ubuntu:~/Desktop$python controlpt.pyPython 程序不完全执行,停止在中间,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
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()