使用485通信远程抄表,获取电能表显示的千瓦时数据

本文主要是介绍使用485通信远程抄表,获取电能表显示的千瓦时数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、接线

  1. 接好电能表的零火线确保电表能够正常上电与显示
  2. 把USB转485或者RS232转485模块的485A连接到电表的A,485B连接到电表的B

二、发送读取指令

2.1使用广播地址获取电表的表号与协议,如果电表的表号与协议是明确的可以跳过这一步

  1. 由于需要使用到广播指令获取电表的表号与协议,所以USB转485或者RS232转485模块上只能连接一个电表

  2. 打开串口助手,波特率设置为1200,数据位8位,校验为偶校验,停止位1位

  3. 通过广播地址确定电表的表号与协议(适用所有电表)
    97年和07年规约数据帧的组成:
    在这里插入图片描述
    指令1:68 AA AA AA AA AA AA 68 11 04 33 33 34 33 AE 16
    指令2:68 99 99 99 99 99 99 68 11 04 33 33 34 33 48 16
    指令3:68 AA AA AA AA AA AA 68 01 02 43 C3 D5 16
    指令4:68 99 99 99 99 99 99 68 01 02 43 C3 6F 16

    如果发送指令1与2有返回则说明电表为07规约,如果发送指令3与4有返回则说明电表为97规约

  4. 对电表的返回数值进行解析,发送指令3之后,如果电表有返回则返回数值,例如:FE 68 85 49 18 00 17 00 68 81 06 43 C3 C7 48 85 39 27 16,说明电表遵守的是97规约。确定出电表的地址为85 49 18 00 17 00(低位在前)
    返回数据解析:
    在这里插入图片描述

**说明:**电表条形码下方的数值都会与指令的地址位相关(下面是网上一款电能表)。表支持RS485通信所以其通信协议肯定是遵循DLT 645-2007或者DLT645-1997,通常支持通信协议也会标注在电表上,但下面这款电报未进行标注,应该是现在购买的表默认遵循DLT 645-2007协议。

请添加图片描述

2.2获取电能表显示的千瓦时数据(以97协议进行测试)

  1. 根据上面发送广播地址电表返回的数据可以确定电表的地址85 49 18 00 17 00(低位在前)和通讯的协议是97,根据这两个信息组合出想要发送的读取电能表千瓦时的数据指令
  2. 发送的数据指令组成解析:FE FE 68 85 49 18 00 17 00 68 01 02 43 C3 D6 16
    在这里插入图片描述
  3. 当电表正常接收和正常返回时,接收到数据FE 68 85 49 18 00 17 00 68 81 06 43 C3 C7 48 85 39 27 16,数据域为C7 48 85 39,数据域的数值减去33后为94 15 52 06,由于数值为低位在前所以拼接起来之后数值为06521594,其中最后两位为小数位则总电能的数值为65215.94kWh,也就是电表显示千瓦时数据(正向有功总功耗)。
    在这里插入图片描述
    说明:上面测试的使用指令3:68 AA AA AA AA AA AA 68 01 02 43 C3 D5 16虽然也能完成电表千瓦时数据(正向有功总功耗)的读取,但是在一个485总线上只能存在一个电表,不能完成一个485总线对多个电表的远程抄表。要实现一个485总线对多个电表的远程抄表则需要使用电表独立的地址进行通信,获取电表数据。

这篇关于使用485通信远程抄表,获取电能表显示的千瓦时数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/377649

相关文章

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

ModelMapper基本使用和常见场景示例详解

《ModelMapper基本使用和常见场景示例详解》ModelMapper是Java对象映射库,支持自动映射、自定义规则、集合转换及高级配置(如匹配策略、转换器),可集成SpringBoot,减少样板... 目录1. 添加依赖2. 基本用法示例:简单对象映射3. 自定义映射规则4. 集合映射5. 高级配置匹

Spring 框架之Springfox使用详解

《Spring框架之Springfox使用详解》Springfox是Spring框架的API文档工具,集成Swagger规范,自动生成文档并支持多语言/版本,模块化设计便于扩展,但存在版本兼容性、性... 目录核心功能工作原理模块化设计使用示例注意事项优缺点优点缺点总结适用场景建议总结Springfox 是

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、