我在使用sanic设置python服务器时出错。服务器启动正常-但是通过终端curl localhost:8000 -i
调用会导致错误。基本上,我想异步调用python函数。该函数解析可移动的温度和湿度传感器。python函数也可以正常工作。我正在使用python函数,因为我在JavaScript中没有任何等价的函数
我试图更改返回的json值,但没有任何更改成功
代码:
#!/usr/bin/env python3
from sanic import Sanic
from sanic.response import json
now = datetime.now()
dt_string = now.strftime("%d/%m %H:%M:%S")
app = Sanic()
@app.route('/')
async def poll(mac):
"""Poll data from the sensor every x (60) seconds."""
while True:
backend = BluepyBackend
poller = MiTempBtPoller(mac, backend)
print("Parsing data")
print("FW: {}".format(poller.firmware_version()))
print("Name: {}".format(poller.name()))
print("Battery: {}".format(poller.parameter_value(MI_BATTERY)))
print("Temperature: {}".format(poller.parameter_value(MI_TEMPERATURE)))
print("Humidity: {}".format(poller.parameter_value(MI_HUMIDITY)))
with open('/home/pi/file.txt', 'a') as myfile:
myfile.write("Time: {}, Battery: {}; Temp: {}; Humidity: {}".format(datetime.now(), poller.parameter_value(MI_BATTERY), poller.parameter_value(MI_TEMPERATURE), \
poller.parameter_value(MI_HUMIDITY)))
return json.dumps({"a": poller.parameter_value(MI_TEMPERATURE)})
sleep(60)
if __name__ == '__main__':
app.run(host='0.0.0.0', port = 8000)
poll('sensormac')
错误:
[2020-11-15 17:46:39 +0100] [1557] [INFO] Goin' Fast @ http://0.0.0.0:8000
[2020-11-15 17:46:39 +0100] [1557] [INFO] Starting worker [1557]
Parsing data
[2020-11-15 17:46:43 +0100] [1557] [ERROR] Exception occurred while handling uri: 'http://localhost:8000/'
Traceback (most recent call last):
File "/home/pi/.local/lib/python3.7/site-packages/sanic/app.py", line 939, in handle_request
response = await response
File "/home/pi/mitemp/btparser_server.py", line 25, in poll
print("FW: {}".format(poller.firmware_version()))
File "/home/pi/mitemp/mitemp_bt/mitemp_bt_poller.py", line 90, in firmware_version
with self._bt_interface.connect(self._mac) as connection:
File "/home/pi/mitemp/btlewrap/base.py", line 47, in __enter__
self._backend.connect(self._mac)
File "/home/pi/mitemp/btlewrap/bluepy.py", line 27, in _func_wrapper
return func(*args, **kwargs)
File "/home/pi/mitemp/btlewrap/bluepy.py", line 56, in connect
self._peripheral = Peripheral(mac, iface=iface, addrType=self.address_type)
File "/usr/local/lib/python3.7/dist-packages/bluepy/btle.py", line 391, in __init__
self._connect(deviceAddr, addrType, iface)
File "/usr/local/lib/python3.7/dist-packages/bluepy/btle.py", line 422, in _connect
if len(addr.split(":")) != 6:
AttributeError: 'Request' object has no attribute 'split'
关于如何修复它有什么建议吗
因此,我通过将
backend = BluepyBackend
和poller = MiTempBtPoller('sensormacID', backend)
放在async def poll(mac)
之前并移除while True: ... sleep(10)
循环,使代码正常工作相关问题 更多 >
编程相关推荐