MyEMS开源能源管理系统核心代码解读010

简介: MyEMS开源能源管理系统支持建筑、工厂等场景的能源数据采集与分析,提供光伏、储能、充电桩等功能。本期解读其碳排放计算脚本 *meter_carbon.py*:通过连接MyEMS数据库,获取能耗数据与碳排放因子,计算并存储碳排放量。脚本实现无限循环处理,确保实时更新,同时具备异常处理和重试机制,保障数据准确性和系统稳定性。此功能助力企业实现低碳发展。

MyEMS开源能源管理系统适用于建筑、工厂、商场、医院、园区的电、水、气等能源数据采集、分析、报表,还有光伏、储能、充电桩、微电网、设备控制、故障诊断、工单管理、人工智能优化等可选功能。资深专业团队开发维护,保障长期支持。用开源助力企业集团、产业园区、能源运营商低碳发展!

本期解读:
计量表碳排放计算方法:myems/myems-aggregation/meter_carbon.py

源代码链接https://gitee.com/myems/myems/blob/master/myems-aggregation/meter_carbon.py?sessionid=-167244909

这段代码是一个用于计算和记录碳排放的Python脚本,它通过连接到MyEMS系统的数据库,获取能耗数据,然后根据能耗数据和碳排放因子计算出碳排放量,并将结果保存回数据库。下面是对代码的详细解析:

摘要

1.连接数据库:脚本首先连接到MyEMS系统的三个数据库:系统数据库、能源数据库和碳数据库。
2.获取所有计量表:从系统数据库中获取所有计量表的信息。
3.循环处理每个计量表:

  • 获取每个计量表的最新开始时间。
  • 从能源数据库中获取该计量表自最新开始时间以来的所有能耗数据。
  • 根据能耗类别获取碳排放因子。
  • 计算碳排放量(能耗数据乘以碳排放因子)。
  • 将计算得到的碳排放数据保存到碳数据库中。
    4.循环等待:完成所有计量表的处理后,脚本等待一段时间(300秒),然后重复上述过程。

    详细解析

    1.连接数据库:
  • 使用mysql.connector.connect连接到MyEMS的系统、能源和碳数据库。
  • 如果连接失败,则记录错误日志,关闭已打开的数据库连接,并等待60秒后重试。
    2.获取所有计量表:
  • 从系统数据库中查询所有计量表的ID、名称、能耗类别和成本中心ID。
  • 如果没有计量表或查询失败,则记录错误日志,关闭数据库连接,并等待60秒后重试。
    3.处理每个计量表:
  • 对于每个计量表,获取其在碳数据库中的最新开始时间。
  • 从能源数据库中获取该计量表自最新开始时间以来的所有能耗数据。
  • 根据能耗类别和时间范围,从carbon_dioxide_emmision_factor模块获取碳排放因子。
  • 计算碳排放量:将能耗数据乘以碳排放因子。
  • 将计算得到的碳排放数据批量插入到碳数据库中。
    4.循环等待:
  • 完成所有计量表的处理后,脚本等待300秒,然后重新开始处理。

注意事项

  • 脚本使用了无限循环来不断处理数据,每次循环结束后会等待一段时间。
  • 在处理过程中,如果遇到任何异常,脚本会记录错误日志,并在等待一段时间后重试。
  • 数据库操作包括读取和写入,需要确保数据库连接的稳定性和数据的准确性。
  • 碳排放的计算依赖于准确的能耗数据和碳排放因子,因此数据的准确性对计算结果至关重要。
相关文章
|
存储 缓存 文件存储
如何保证分布式文件系统的数据一致性
分布式文件系统需要向上层应用提供透明的客户端缓存,从而缓解网络延时现象,更好地支持客户端性能水平扩展,同时也降低对文件服务器的访问压力。当考虑客户端缓存的时候,由于在客户端上引入了多个本地数据副本(Replica),就相应地需要提供客户端对数据访问的全局数据一致性。
31853 78
如何保证分布式文件系统的数据一致性
|
前端开发 容器
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局(上)
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局
17655 18
|
人工智能 负载均衡 网络性能优化
灵骏可预期网络:Built for AI Infrastructure
通用人工智能离我们越来越近,全世界的关注和投入正在带来日新“周”异的变化。回顾人工智能的诞生和发展历程,人类计算能力的进步几乎牵动了每一次的重大技术突破,当前的大模型热潮更是如此,只是动辄千万亿参数级的模型体量,所需计算资源远超单颗芯片的上限,超大规模的计算集群成为支撑技术发展和应用创新的关键基础设施。面向智能:云基础设施网络技术面临新挑战如何突破单个芯片、单个服务器节点的算力上限,在超大规模情况
31193 10
灵骏可预期网络:Built for AI Infrastructure
|
设计模式 存储 监控
设计模式(C++版)
看懂UML类图和时序图30分钟学会UML类图设计原则单一职责原则定义:单一职责原则,所谓职责是指类变化的原因。如果一个类有多于一个的动机被改变,那么这个类就具有多于一个的职责。而单一职责原则就是指一个类或者模块应该有且只有一个改变的原因。bad case:IPhone类承担了协议管理(Dial、HangUp)、数据传送(Chat)。good case:里式替换原则定义:里氏代换原则(Liskov 
36193 19
设计模式(C++版)
|
存储 编译器 C语言
抽丝剥茧C语言(初阶 下)(下)
抽丝剥茧C语言(初阶 下)
|
机器学习/深度学习 人工智能 自然语言处理
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
24468 14
|
机器学习/深度学习 弹性计算 监控
重生之---我测阿里云U1实例(通用算力型)
阿里云产品全线降价的一力作,2023年4月阿里云推出新款通用算力型ECS云服务器Universal实例,该款服务器的真实表现如何?让我先测为敬!
36515 15
重生之---我测阿里云U1实例(通用算力型)
为笔记本更换固态硬盘的方法
本文介绍为笔记本电脑拆机、更换固态硬盘的具体方法~
18011 41
为笔记本更换固态硬盘的方法
|
SQL 存储 弹性计算
Redis性能高30%,阿里云倚天ECS性能摸底和迁移实践
Redis在倚天ECS环境下与同规格的基于 x86 的 ECS 实例相比,Redis 部署在基于 Yitian 710 的 ECS 上可获得高达 30% 的吞吐量优势。成本方面基于倚天710的G8y实例售价比G7实例低23%,总性价比提高50%;按照相同算法,相对G8a,性价比为1.4倍左右。
|
存储 算法 Java
【分布式技术专题】「分布式技术架构」手把手教你如何开发一个属于自己的限流器RateLimiter功能服务
随着互联网的快速发展,越来越多的应用程序需要处理大量的请求。如果没有限制,这些请求可能会导致应用程序崩溃或变得不可用。因此,限流器是一种非常重要的技术,可以帮助应用程序控制请求的数量和速率,以保持稳定和可靠的运行。
29747 52