sgcc_electricity

v1.2 Folk 版本更新日志

  1. 修复新的一年95598网站数据为空的问题

  2. 增加sensor属性, 以便于更好地识别

v1.1 更新日志

1.适配多个户号(多个户号相关的实体名称、UI配置(如需),见使用说明)

2.增加查看年用电量、电费

3.优化部分已知bug


升级指引

1. addon 部署,且按照使用说明从git上clone过仓库

输入以下命令,从github上拉取代码

cd /addons/sgcc_electricity
git pull

然后在webUI上点击配置-》加载项-》加载项商店,加载项商店又上角点击检查更新。然后再点击sgcc_electricity加载项,这时候你就可以看到升级功能了;如果没有的话,也无妨,直接点击重新编译。

升级过程持续时间很长,可以按照使用说明中的addon部署部分了解如何查看进度

2. docker 部署,且按照使用说明从git上clone过仓库

输入以下命令,从github上拉取代码

cd sgcc_electricity
git pull

然后按照使用说明中的docker部署部分,执行build, run就行

3. 直接部署--适用于适用core部署HA的朋友

使用core的朋友已经脱离新手阶段了,所以此处就不写说明啦~


使用说明

本应用可以帮助你将国网的电费、用电量数据接入HA,适用于除南方电网覆盖省份外的用户。即除广东、广西、云南、贵州、海南等省份的用户外,均可使用本应用获取电力、电费数据。

本应用每12小时抓取一次数据,并在HA里更新以下四个实体

sensor.last_electricity_usage:最近一天用电量
sensor.electricity_charge_balance:电费余额
sensor.yearly_electricity_usage: 今年以来用电量
sensor.yearly_electricity_charge: 今年以来电费

注:如果你有一个户号,在HA里就是以上实体名;如果你有多个户号,实体名称还要加 “_户号”后缀,举例:sensor.last_electricity_usage_1234567890

由于采用REST API方式创建sensor,没有做实体注册,无法在webui里编辑。如果需要,你可以在configuration.yaml下增加如下配置后重启HA,这样你就可在webUI编辑对应的实体了。

如果你有一个户号,参照以下配置

template:
  - trigger:
      - platform: event
        event_type: "state_changed"
        event_data: 
          entity_id: sensor.electricity_charge_balance 
    sensor:
      - name: electricity_charge_balance_entity
        unique_id: electricity_charge_balance_entity
        state: "{{ states('sensor.electricity_charge_balance') }}"
        state_class: measurement
        unit_of_measurement: "CNY"
 
  - trigger:
      - platform: event
        event_type: "state_changed"
        event_data: 
          entity_id: sensor.last_electricity_usage
    sensor:
      - name: last_electricity_usage_entity
        unique_id: last_electricity_usage_entity
        state: "{{ states('sensor.last_electricity_usage') }}"
        state_class: measurement
        unit_of_measurement: "KWH"

  - trigger:
      - platform: event
        event_type: "state_changed"
        event_data: 
          entity_id: sensor.yearly_electricity_usage
    sensor:
      - name: yearly_electricity_usage_entity
        unique_id: yearly_electricity_usage_entity
        state: "{{ states('sensor.yearly_electricity_usage') }}"
        state_class: measurement
        unit_of_measurement: "KWH"
  
  - trigger:
      - platform: event
        event_type: "state_changed"
        event_data: 
          entity_id: sensor.yearly_electricity_charge
    sensor:
      - name: yearly_electricity_charge_entity
        unique_id: yearly_electricity_charge_entity
        state: "{{ states('sensor.yearly_electricity_charge') }}"
        state_class: measurement
        unit_of_measurement: "CNY"

如果你有多个户号,每个户号参照以下配置

template:
  - trigger:
      - platform: event
        event_type: "state_changed"
        event_data: 
          entity_id: sensor.electricity_charge_balance_户号
    sensor:
      - name: electricity_charge_balance_户号_entity
        unique_id: electricity_charge_balance_户号_entity
        state: "{{ states('sensor.electricity_charge_balance_户号') }}"
        state_class: measurement
        unit_of_measurement: "CNY"
 
  - trigger:
      - platform: event
        event_type: "state_changed"
        event_data: 
          entity_id: sensor.last_electricity_usage_户号
    sensor:
      - name: last_electricity_usage_户号_entity
        unique_id: last_electricity_usage_户号_entity
        state: "{{ states('sensor.last_electricity_usage_户号') }}"
        state_class: measurement
        unit_of_measurement: "KWH"

  - trigger:
      - platform: event
        event_type: "state_changed"
        event_data: 
          entity_id: sensor.yearly_electricity_usage_户号
    sensor:
      - name: yearly_electricity_usage_户号_entity
        unique_id: yearly_electricity_usage_户号_entity
        state: "{{ states('sensor.yearly_electricity_usage_户号') }}"
        state_class: measurement
        unit_of_measurement: "KWH"
  
  - trigger:
      - platform: event
        event_type: "state_changed"
        event_data: 
          entity_id: sensor.yearly_electricity_charge_户号
    sensor:
      - name: yearly_electricity_charge_户号_entity
        unique_id: yearly_electricity_charge_户号_entity
        state: "{{ states('sensor.yearly_electricity_charge_户号') }}"
        state_class: measurement
        unit_of_measurement: "CNY"

使用方法一:直接作为add-on接入

如果你是采用supervised, HAOS方式部署的home-assistant(也就是说你部署了suppervisor, add-on等容器),可以使用local add-on的方式接入.

首先,进入HA实例终端,输入以下命令从git上clone仓库。

cd /addons
git clone https://github.com/louisslee/sgcc_electricity.git
cd sgcc_electricity
chmod 777 run.sh

然后在webUI上点击配置-》加载项-》加载项商店,这时你应该可以看到local下面的本add-on(没看到的话,加载项商店又上角点击检查更新,再不行你可以试试重启supervisor)。

由于这个项目较大(docker image约1.17GB),build过程较慢,预计持续半小时左右(视网速、科学情况有所差异),先喝杯奶茶休息下再回来吧:)

如果你想了解setup进度,可以在HA终端上输入docker container ls,复制第一个container的name,执行docker container attach {替换成container name},来查看安装进度。

安装好后,配置好用户名、密码,直接启动即可。稍等1分钟后,就可以在HA中找到本说明开篇写的实体了。

使用方法二:docker部署

如果你是采用core, docker方式部署的home-assistant(也就是说你没有部署suppervisor, add-on等容器),建议采用docker部署本应用。

首先请在HA webUI上建立一个长期访问令牌,点击webUI左下角用户名拉到最下面就可以看到了。

在宿主机上打开压缩包后,可输入如下命令执行docker构建、部署。

git clone https://github.com/louisslee/sgcc_electricity.git
cd sgcc_electricity
chmod 777 run.sh
docker build -t sgcc_electricity:1.1 .
docker run --name sgcc_electricity -d -e PHONE_NUMBER="" -e PASSWORD="" -e HASS_URL="" -e HASS_TOKEN="" --restart unless-stopped sgcc_electricity:1.1 

由于这个项目较大(docker image约1.17GB),build过程较慢,我在ubuntu上build了十多分钟。

部署container成功后稍等1分钟,你就可以在HA中找到本说明开篇写的实体了。

使用方法三:直接部署

如果你宿主机是ubuntu,centos, debian等linux操作系统,底层C库是glibc等manylinux tag可兼容的,你可以直接在宿主机上部署本应用(如果底层C库是musl(如alpine OS), 需要先自行编译onnxruntime)

首先安装本项目依赖,可参考:

pip3 install selenium==4.5.0, schedule==1.1.0, ddddocr==1.4.7, undetected_webdriver==3.1.6
apt-get install jq chromium chromium-driver -y 

将文件解压后,执行python脚本即可。可根据需求自行将其设置为开机自启动或是跟随HA自启动。

cd sgcc_electricity
nohup python3 main.py --PHONE_NUMBER= --PASSWORD= --HASS_URL= --HASS_TOKEN= &

其他

如果你是以core的方式部署的HA,你还可以自己改改,搞一个自定义集成。