『瀚思彼岸』» 智能家居技术论坛

 找回密码
 立即注册
查看: 6546|回复: 7

[求助] 接入京东万象天气PY文件报错,求教

[复制链接]

15

主题

146

帖子

660

积分

高级会员

Rank: 4

积分
660
金钱
513
HASS币
0
发表于 2017-12-21 14:20:44 | 显示全部楼层 |阅读模式
https://wx.jcloud.com/market/datas/26/10610 万象API地址

https://www.hachina.io/docs/1976.html 按照这个教程直接复制py文件上传。


现在报错信息。
Error while setting up platform hachina
Traceback (most recent call last):
  File "/srv/homeassistant/homeassistant_venv/lib/python3.5/site-packages/homeassistant/helpers/entity_component.py", line 171, in _async_setup_platform
    SLOW_SETUP_MAX_WAIT, loop=self.hass.loop)
  File "/usr/lib/python3.5/asyncio/tasks.py", line 392, in wait_for
    return fut.result()
  File "/usr/lib/python3.5/asyncio/futures.py", line 274, in result
    raise self._exception
  File "/usr/lib/python3.5/concurrent/futures/thread.py", line 55, in run
    result = self.fn(*self.args, **self.kwargs)
  File "/srv/homeassistant/homeassistant_venv/lib/python3.5/site-packages/homeassistant/components/sensor/hachina.py", line 55, in setup_platform
    data = WeatherData(hass, city, appkey)
  File "/srv/homeassistant/homeassistant_venv/lib/python3.5/site-packages/homeassistant/components/sensor/hachina.py", line 135, in __init__
    self.update(dt_util.now())
  File "/srv/homeassistant/homeassistant_venv/lib/python3.5/site-packages/homeassistant/components/sensor/hachina.py", line 179, in update
    all_result = result["result"]["HeWeather5"][0]
KeyError: 'HeWeather5'


想了解一下原因。学习自己做插件。请熟悉python的大神指点一下。谢谢

回复

使用道具 举报

32

主题

986

帖子

4233

积分

论坛元老

Rank: 8Rank: 8

积分
4233
金钱
3207
HASS币
110

教程狂人论坛风云人物

发表于 2017-12-21 15:11:58 | 显示全部楼层
这个L大应该在行,帮你顶一下
回复

使用道具 举报

15

主题

146

帖子

660

积分

高级会员

Rank: 4

积分
660
金钱
513
HASS币
0
 楼主| 发表于 2017-12-21 17:25:04 | 显示全部楼层
27hh 发表于 2017-12-21 15:11
这个L大应该在行,帮你顶一下

谢谢支持。小白要学的东西太多了
回复

使用道具 举报

1

主题

158

帖子

678

积分

高级会员

Rank: 4

积分
678
金钱
519
HASS币
0
发表于 2018-11-6 00:21:11 | 显示全部楼层
本帖最后由 ctrai88 于 2018-11-6 00:23 编辑

https://www.hachina.io/dwqa-question/9812.html

我的同样报错:Invalid config for [sensor.hachina]: value is not allowed @ data[‘options’][0]. Got ‘coldrisk’. (See ?, line ?). Please check the docs at https://home-assistant.io/components/sensor.hachina/
回复

使用道具 举报

1

主题

158

帖子

678

积分

高级会员

Rank: 4

积分
678
金钱
519
HASS币
0
发表于 2018-11-6 00:25:59 | 显示全部楼层
修改后代码如下:
"""
文件名:hachina.py.
 
文件位置:HomeAssistant配置目录/custom_components/sensor/hachina.py
演示程序,一个平台实现多个传感器.
 
"""
 
import json
from urllib import request, parse
import logging
from datetime import timedelta
import voluptuous as vol
 
from homeassistant.components.sensor import PLATFORM_SCHEMA
from homeassistant.const import (
    ATTR_ATTRIBUTION, ATTR_FRIENDLY_NAME, TEMP_CELSIUS)
from homeassistant.helpers.entity import Entity
import homeassistant.helpers.config_validation as cv
from homeassistant.helpers.event import track_time_interval
import homeassistant.util.dt as dt_util
 
 
_LOGGER = logging.getLogger(__name__)
 
TIME_BETWEEN_UPDATES = timedelta(seconds=600)
 
# 配置文件中三个配置项的名称
CONF_OPTIONS = "options"
CONF_CITY = "city"
CONF_APPKEY = "appkey"
 
# 定义三个可选项:温度、湿度、PM2.5
# 格式:配置项名称:[OBJECT_ID, friendly_name, icon, 单位]
OPTIONS = {
     "coldrisk": ["hachina_coldrisk", "感冒指数", "mdi:hospital", "%"],
    "temprature": ["hachina_temperature", "室外温度", "mdi:thermometer", TEMP_CELSIUS],
    "humidity": ["hachina_humidity", "室外湿度", "mdi:water-percent", "%"],
    "pm25": ["hachina_pm25", "PM2.5", "mdi:walk", "μg/m3"],
}
 
ATTR_UPDATE_TIME = "更新时间"
ATTRIBUTION = "京东万象天气数据"
 
 
PLATFORM_SCHEMA = PLATFORM_SCHEMA.extend({
    vol.Required(CONF_CITY): cv.string,
    vol.Required(CONF_APPKEY): cv.string,
    # 配置项的options是一个列表,列表内容只能是OPTIONS中定义的三个可选项
    vol.Required(CONF_OPTIONS,
                 default=[]): vol.All(cv.ensure_list, [vol.In(OPTIONS)]),
})
 
 
def setup_platform(hass, config, add_devices, discovery_info=None):
    """根据配置文件,setup_platform函数会自动被系统调用."""
    _LOGGER.info("setup platform sensor.hachina...")
 
    city = config.get(CONF_CITY)
    appkey = config.get(CONF_APPKEY)
 
    # 定义一个新的数据对象,用于从京东万象获取并存储天气数据。Sensor的实际数据从这个对象中获得。
    data = WeatherData(hass, city, appkey)
 
    # 根据配置文件options中的内容,添加若干个设备
    dev = []
    for option in config[CONF_OPTIONS]:
        dev.append(HAChinaWeatherSensor(data, option))
    add_devices(dev, True)
 
 
class HAChinaWeatherSensor(Entity):
    """定义一个温度传感器的类,继承自HomeAssistant的Entity类."""
 
    def __init__(self, data, option):
        """初始化."""
        self._data = data
        self._object_id = OPTIONS[option][0]
        self._friendly_name = OPTIONS[option][1]
        self._icon = OPTIONS[option][2]
        self._unit_of_measurement = OPTIONS[option][3]
 
        self._type = option
        self._state = None
        self._updatetime = None
 
    @property
    def name(self):
        """返回实体的名字."""
        return self._object_id
 
    @property
    def registry_name(self):
        """返回实体的friendly_name属性."""
        return self._friendly_name
 
    @property
    def state(self):
        """返回当前的状态."""
        return self._state
 
    @property
    def icon(self):
        """返回icon属性."""
        return self._icon
 
    @property
    def unit_of_measurement(self):
        """返回unit_of_measuremeng属性."""
        return self._unit_of_measurement
 
    @property
    def device_state_attributes(self):
        """设置其它一些属性值."""
        if self._state is not None:
            return {
                ATTR_ATTRIBUTION: ATTRIBUTION,
                ATTR_UPDATE_TIME: self._updatetime
            }
 
    def update(self):
        """更新函数,在sensor组件下系统会定时自动调用(时间间隔在配置文件中可以调整,缺省为30秒)."""
        # update只是从WeatherData中获得数据,数据由WeatherData维护。
        self._updatetime = self._data.updatetime
        if self._type == "coldrisk":
            self._state = self._data.coldrisk 
        if self._type == "temprature":
            self._state = self._data.temprature
        elif self._type == "humidity":
            self._state = self._data.humidity
        elif self._type == "pm25":
            self._state = self._data.pm25
 
 
class WeatherData(object):
    """天气相关的数据,存储在这个类中."""
 
    def __init__(self, hass, city, appkey):
        """初始化函数."""
        self._url = "https://way.jd.com/he/freeweather"
        self._params = {"city": city,
                        "appkey": appkey}
        self._coldrisk = None   
        self._temprature = None             
        self._humidity = None
        self._pm25 = None
        self._updatetime = None
 
        self.update(dt_util.now())
        # 每隔TIME_BETWEEN_UPDATES,调用一次update(),从京东万象获取数据
        track_time_interval(hass, self.update, TIME_BETWEEN_UPDATES)
 
    @property
    def coldrisk(self):
        """感冒指数."""
        return self._coldrisk

    @property
    def temprature(self):
        """温度."""
        return self._temprature
 
    @property
    def humidity(self):
        """湿度."""
        return self._humidity
 
    @property
    def pm25(self):
        """pm2.5."""
        return self._pm25
 
    @property
    def updatetime(self):
        """更新时间."""
        return self._updatetime
 
    def update(self, now):
        """从远程更新信息."""
        _LOGGER.info("Update from JingdongWangxiang's OpenAPI...")
 
        # 通过HTTP访问,获取需要的信息
        infomation_file = request.urlopen(
            self._url, parse.urlencode(self._params).encode('utf-8'))
 
        content = infomation_file.read()
        result = json.loads(content.decode('utf-8'))
 
        if result is None:
            _LOGGER.error("Request api Error")
            return
        elif result["code"] != "10000":
            _LOGGER.error("Error API return, code=%s, msg=%s",
                          result["code"],
                          result["msg"])
            return
 
        # 根据http返回的结果,更新数据
        all_result = result["result"]["HeWeather5"][0]
        self._coldrisk = all_result["now"]["fl"]
        self._temprature = all_result["now"]["tmp"]
        self._humidity = all_result["now"]["hum"]
        self._pm25 = all_result["aqi"]["city"]["pm25"]
        self._updatetime = all_result["basic"]["update"]["loc"]


回复

使用道具 举报

1

主题

158

帖子

678

积分

高级会员

Rank: 4

积分
678
金钱
519
HASS币
0
发表于 2018-11-6 22:13:28 | 显示全部楼层
经过重启,问题解决。
回复

使用道具 举报

1

主题

158

帖子

678

积分

高级会员

Rank: 4

积分
678
金钱
519
HASS币
0
发表于 2018-11-6 22:16:34 | 显示全部楼层

                               
登录/注册后可看大图

回复

使用道具 举报

1

主题

158

帖子

678

积分

高级会员

Rank: 4

积分
678
金钱
519
HASS币
0
发表于 2018-11-6 22:20:12 | 显示全部楼层
[size=15.9962px]重启后问题解决。

京东万象天气

京东万象天气
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Hassbian

GMT+8, 2024-11-24 04:12 , Processed in 0.181361 second(s), 34 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表