批量修改元件及设备参数
功能介绍
在 IESLab 仿真建模平台利用 SDK 实现设置项目经纬度位置坐标及获取气象数据,并对设备、负荷及能源信息库进行增删改查。
使用说明
用到的 API
- 静态方法
方法 功能 IESLabSimulation.fetch(simulationId)
获取算例信息 - 实例方法
方法 功能 IESLabSimulation.run(job=None, name=None)
调用仿真
- 实例方法
方法 功能 Job.status()
运行状态
- 实例方法
方法 功能 IESResult.getPlotData(compID, labelName, traceName='all', index=-1)
获取元件 ID 为 compID
的元件,对应标签为labelName
、图例名称为traceName
的第index
项数据
- 实例方法
方法 功能 dataManageModel.SetProjectPosition(longitude, latitude)
将项目的经纬度位置坐标设置为 longitude
,latitude
dataManageModel.GetAtmosData(startDate, endDate)
获取在 startDate
到endDate
之间的气象数据dataManageModel.GetItemList(dataType)
获取 dataType
类型对应所有数据项的列表dataManageModel.AddDataItem(dataType, data)
向 dataType
类型的数据库中添加内容为data
的数据项dataManageModel.UpdateDataItem(ID: str, data)
更新数据库 ID
对应数据项data
的数据dataManageModel.DeleteDataItem(ID: str)
删除 ID
对应数据项
- 实例方法
方法 功能 Model.getComponentByKey(componentKey: str)
通过 componentKey
获取对应的元件
调用方式
- 通过
IESLabSimulation.fetch(simulationId)
获取算例信息,随后通过IESLabSimulation.run(job=None, name=None)
方法调用仿真计算,最后通过IESResult.getPlotData(compID, labelName, traceName='all', index=-1)
方法获取元件的仿真计算结果数据。 - 通过
dataManageModel.SetProjectPosition(longitude, latitude)
方法设置项目经纬度,通过dataManageModel.GetAtmosData(startDate, endDate)
方法获取指定时段的气象数据。 - 通过
DataManageModel
类的相应方法对数据管理模块的数据项进行增删改查操作。
案例介绍
接下来,通过一个完整的案例来展示如何基于上述 API 编写 Python 脚本,对数据管理模块进行操作。此外,还展示了如何修改元件的参数。这些操作对于在仿真环境中准确模拟综合能源系统的实际工作条件至关重要。
代码解析
首先进行案例准备工作。设置网址与账户 token
、获取获取算例并进行仿真计算。
import time
import os
import cloudpss
if __name__ == '__main__':
# 设置API访问令牌和API地址
cloudpss.setToken('{token}')
os.environ['CLOUDPSS_API_URL'] = 'https://cloudpss.net/'
# 获取模型对象
iesProject = cloudpss.IESLabSimulation.fetch(1888)
# 仿真计算测试
runner = iesProject.run()
while not runner.status():
print('running', flush=True)
time.sleep(3)
print('计算完成')
ies_result = runner.result
通过 iesProject.dataManageModel.SetProjectPosition(longitude, latitude)
方法设置项目的地理位置坐标。这一步非常重要,因为很多能源系统的性能与地理位置密切相关,如光伏发电受当地日照条件影响。
#获取与修改数据管理模块信息
#设定项目经纬度位置坐标
longitude, latitude = 120.5, 33.0
iesProject.dataManageModel.SetProjectPosition(longitude, latitude)
使用 iesProject.dataManageModel.GetAtmosData(startDate, endDate)
方法获取指定时间段内的气象数据。注意日期格式应为 "YYYY-MM-DD" 的字符串形式。
#获取某时间段的气象数据
startDate = "2021-01-01"
endDate = "2021-01-02"
atmosData = iesProject.dataManageModel.GetAtmosData(startDate, endDate)
GetItemList('光伏')
用于获取类型为 光伏
的所有设备数据列表。AddDataItem('光伏', data_PV[0])
用于添加一个新的光伏设备数据项,第二个参数为新数据对象。通过修改 data_PV[0]['ratedParam']['MaximumPower']
来更新最大功率参数。UpdateDataItem(data_PV[1]['id'], data_PV[0])
用于更新 id 为 data_PV[1]['id']
的数据项,第二个参数为更新后的数据对象。DeleteDataItem(data_PV[-1]['id'])
用于删除最后一个光伏设备数据项。在进行数据项的修改、更新和删除操作时,确保传递的参数正确,特别是数据项的 ID。
#数据管理模块中的数据获取、修改、更新及删除
data_PV = iesProject.dataManageModel.GetItemList('光伏')
trueAdd = iesProject.dataManageModel.AddDataItem('光伏',data_PV[0])
data_PV[0]['ratedParam']['MaximumPower'] = str(790)
trueUpdate = iesProject.dataManageModel.UpdateDataItem(data_PV[1]['id'],data_PV [0])
trueDelete = iesProject.dataManageModel.DeleteDataItem(data_PV[-1]['id'])
获取与修改拓扑编辑模块信息。model.getComponentByKey("PhotovoltaicSys_6")
根据关键字获取特定的光伏组件对象。通过 model_pv.args['DipAngle'] = str(40)
修改元件的倾角参数为 40 度。
#获取与修改拓扑编辑模块信息
# 修改参数值
model = iesProject.model
model_pv=model.getComponentByKey("PhotovoltaicSys_6")
model_pv.args['DipAngle'] = str(40)
再次运行仿真计算并获取修改参数后的结果数据。
# 仿真计算测试
runner = iesProject.run()
while not runner.status():
print('running', flush=True)
time.sleep(3)
print('计算完成')
ies_result = runner.result
# 示例:使用 getPlotData 方法
compID = "/PhotovoltaicSys_6"
labelName = "功率($\mathrm{kW}$)"
plot_data = ies_result.getPlotData(compID, labelName)
print("Plot data: ", plot_data)
在规划平台同样具备以上的功能点,在使用的时候需要将获取模型的方法 cloudpss.IESLabSimulation.fetch(id)
改为 cloudpss.IESLabPlan.fetch(id)
,其余的操作方法与仿真平台类似。