Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
U
unify_api2
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
chaonan
unify_api2
Commits
4af81566
Commit
4af81566
authored
Jun 02, 2023
by
ZZH
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
remove es 2023-6-2
parent
cccfde1f
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
117 additions
and
498 deletions
+117
-498
common_dao.py
unify_api/modules/common/dao/common_dao.py
+0
-26
health_score.py
unify_api/modules/common/procedures/health_score.py
+48
-48
mqtt_helper.py
unify_api/modules/device_cloud/procedures/mqtt_helper.py
+20
-81
mqtt_helper.py
unify_api/modules/device_mqtt/procedures/mqtt_helper.py
+14
-30
elec_statis_proxy_pds.py
...i/modules/elec_charge/procedures/elec_statis_proxy_pds.py
+5
-63
elec_statis_proxy.py
unify_api/modules/elec_charge/views/elec_statis_proxy.py
+6
-6
count_info_pds.py
unify_api/modules/home_page/procedures/count_info_pds.py
+1
-55
health_index_service.py
unify_api/modules/home_page/service/health_index_service.py
+10
-178
count_info.py
unify_api/modules/home_page/views/count_info.py
+2
-2
health_index.py
unify_api/modules/home_page/views/health_index.py
+10
-8
hardware_info.py
unify_api/modules/product_info/service/hardware_info.py
+1
-1
No files found.
unify_api/modules/common/dao/common_dao.py
View file @
4af81566
...
@@ -61,15 +61,6 @@ async def points_monitor_by_cid(cids):
...
@@ -61,15 +61,6 @@ async def points_monitor_by_cid(cids):
return
points
return
points
async
def
mid_by_pid
(
pid
):
"""根据pid查询mid"""
sql
=
"select mtid from point where pid=
%
s "
\
"order by create_time desc limit 1 "
async
with
MysqlUtil
()
as
conn
:
mid_dic
=
await
conn
.
fetchone
(
sql
,
args
=
(
pid
,))
return
mid_dic
async
def
get_point_monitor_dao
(
pid
):
async
def
get_point_monitor_dao
(
pid
):
sql
=
"SELECT m.meter_no,m.mtid,m.sid,"
\
sql
=
"SELECT m.meter_no,m.mtid,m.sid,"
\
"p.ctr,p.ptr,p.ctnum,p.vc,p.tc,p.imax"
\
"p.ctr,p.ptr,p.ctnum,p.vc,p.tc,p.imax"
\
...
@@ -88,14 +79,6 @@ async def get_location_monitor_dao(lid):
...
@@ -88,14 +79,6 @@ async def get_location_monitor_dao(lid):
return
datas
return
datas
async
def
meter_by_mid
(
mid
):
"""根据mid查询meter"""
sql
=
"select mid,sid,meter_no from meter where mid=
%
s"
async
with
MysqlUtil
()
as
conn
:
meter_dic
=
await
conn
.
fetchone
(
sql
,
args
=
(
mid
,))
return
meter_dic
async
def
meter_by_mids
(
mids
):
async
def
meter_by_mids
(
mids
):
"""根据mids查询meter"""
"""根据mids查询meter"""
sql
=
"select * from meter where mid in
%
s"
sql
=
"select * from meter where mid in
%
s"
...
@@ -135,15 +118,6 @@ async def meter_param_by_mid(mtid):
...
@@ -135,15 +118,6 @@ async def meter_param_by_mid(mtid):
return
meter_param_dic
return
meter_param_dic
async
def
change_sensor_by_location
(
location_id
):
"""根据location_id查询change_sensor_record"""
sql
=
"select location_id,sid,field from change_sensor_record "
\
"where location_id=
%
s order by start_time desc limit 1"
async
with
MysqlUtil
()
as
conn
:
sensor_dic
=
await
conn
.
fetchone
(
sql
,
args
=
(
location_id
,))
return
sensor_dic
async
def
tsp_by_cid
(
cid
):
async
def
tsp_by_cid
(
cid
):
"""根据cid查询points"""
"""根据cid查询points"""
sql
=
"SELECT tsp_id, name FROM tsp WHERE cid =
%
s "
\
sql
=
"SELECT tsp_id, name FROM tsp WHERE cid =
%
s "
\
...
...
unify_api/modules/common/procedures/health_score.py
View file @
4af81566
...
@@ -12,7 +12,7 @@ from unify_api.modules.common.procedures.points import load_compy_points
...
@@ -12,7 +12,7 @@ from unify_api.modules.common.procedures.points import load_compy_points
from
unify_api.modules.electric.procedures.electric_util
import
\
from
unify_api.modules.electric.procedures.electric_util
import
\
batch_get_wiring_type
batch_get_wiring_type
from
unify_api.modules.home_page.procedures
import
point_inlines
from
unify_api.modules.home_page.procedures
import
point_inlines
from
unify_api.constants
import
FREQ_STANDARD
,
POINT_15MIN_INDEX
from
unify_api.constants
import
FREQ_STANDARD
from
unify_api.modules.home_page.procedures.dev_grade
import
get_dev_score
from
unify_api.modules.home_page.procedures.dev_grade
import
get_dev_score
...
@@ -29,12 +29,12 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -29,12 +29,12 @@ async def load_health_radar(cid, param_point_id=None):
# if json_score:
# if json_score:
# score_info = json.loads(json_score)
# score_info = json.loads(json_score)
# return score_info
# return score_info
# 计算最近7天时间起始
# 计算最近7天时间起始
today
=
pendulum
.
today
()
today
=
pendulum
.
today
()
start_time
=
str
(
today
.
subtract
(
days
=
7
))
start_time
=
str
(
today
.
subtract
(
days
=
7
))
end_time
=
str
(
today
.
subtract
(
seconds
=
1
))
end_time
=
str
(
today
.
subtract
(
seconds
=
1
))
inline_point_ids
=
[]
inline_point_ids
=
[]
point_ids
=
[]
point_ids
=
[]
# 1. 获取该工厂所有进线数据
# 1. 获取该工厂所有进线数据
...
@@ -47,7 +47,7 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -47,7 +47,7 @@ async def load_health_radar(cid, param_point_id=None):
inline_point_ids
.
append
(
pid
)
inline_point_ids
.
append
(
pid
)
else
:
else
:
point_ids
.
append
(
pid
)
point_ids
.
append
(
pid
)
# 对如下性能差代码做修改
# 对如下性能差代码做修改
stats
=
{
point_id
:
{}
for
point_id
in
inline_point_ids
+
point_ids
}
stats
=
{
point_id
:
{}
for
point_id
in
inline_point_ids
+
point_ids
}
point_info_map
=
await
batch_get_wiring_type
(
inline_point_ids
+
point_ids
)
point_info_map
=
await
batch_get_wiring_type
(
inline_point_ids
+
point_ids
)
...
@@ -64,7 +64,7 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -64,7 +64,7 @@ async def load_health_radar(cid, param_point_id=None):
else
:
else
:
stats_items
=
[
"uab_mean"
,
"freq_mean"
,
"ubl_mean"
,
"costtl_mean"
,
stats_items
=
[
"uab_mean"
,
"freq_mean"
,
"ubl_mean"
,
"costtl_mean"
,
"lf_mean"
]
"lf_mean"
]
for
item
in
stats_items
:
for
item
in
stats_items
:
point_v
=
es_dic
.
get
(
point_id
)
point_v
=
es_dic
.
get
(
point_id
)
if
not
point_v
:
if
not
point_v
:
...
@@ -122,7 +122,7 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -122,7 +122,7 @@ async def load_health_radar(cid, param_point_id=None):
i
[
"pid"
]:
i
[
"mtid"
]
for
i
in
change_meter_records
if
i
[
"pid"
]:
i
[
"mtid"
]
for
i
in
change_meter_records
if
i
[
"mtid"
]
is
not
None
i
[
"mtid"
]
is
not
None
}
}
# 获取meter_param_record中的标准电压
# 获取meter_param_record中的标准电压
all_mids
=
list
(
point_mid_map
.
values
())
all_mids
=
list
(
point_mid_map
.
values
())
meter_param_map
=
{}
meter_param_map
=
{}
...
@@ -132,7 +132,7 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -132,7 +132,7 @@ async def load_health_radar(cid, param_point_id=None):
meter_param_records
=
await
conn
.
fetchall
(
sql
,
meter_param_records
=
await
conn
.
fetchall
(
sql
,
args
=
(
tuple
(
all_mids
),))
args
=
(
tuple
(
all_mids
),))
meter_param_map
=
{
i
[
"mtid"
]:
i
for
i
in
meter_param_records
}
meter_param_map
=
{
i
[
"mtid"
]:
i
for
i
in
meter_param_records
}
log
.
info
(
f
"all_mids={all_mids}"
)
log
.
info
(
f
"all_mids={all_mids}"
)
# 电压偏差评分
# 电压偏差评分
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
...
@@ -140,7 +140,7 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -140,7 +140,7 @@ async def load_health_radar(cid, param_point_id=None):
ua_mean
=
stats
.
get
(
point_id
,
{})
.
get
(
"ua_mean"
)
ua_mean
=
stats
.
get
(
point_id
,
{})
.
get
(
"ua_mean"
)
if
ua_mean
is
None
:
if
ua_mean
is
None
:
continue
continue
mtid
=
point_mid_map
.
get
(
point_id
)
mtid
=
point_mid_map
.
get
(
point_id
)
if
not
mtid
:
if
not
mtid
:
# pid没有mid,拆了
# pid没有mid,拆了
...
@@ -155,47 +155,47 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -155,47 +155,47 @@ async def load_health_radar(cid, param_point_id=None):
stand_voltage
=
meter_vc
/
sqrt
(
3
)
if
ctnum
==
3
else
meter_vc
stand_voltage
=
meter_vc
/
sqrt
(
3
)
if
ctnum
==
3
else
meter_vc
else
:
else
:
stand_voltage
=
400
if
ctnum
==
3
else
10000
stand_voltage
=
400
if
ctnum
==
3
else
10000
v_dev
=
(
ua_mean
-
stand_voltage
)
/
stand_voltage
v_dev
=
(
ua_mean
-
stand_voltage
)
/
stand_voltage
score
=
get_dev_score
(
dev_type
=
"v"
,
cur
=
v_dev
)
score
=
get_dev_score
(
dev_type
=
"v"
,
cur
=
v_dev
)
if
score
is
None
:
if
score
is
None
:
continue
continue
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
v_score
=
total_score
/
total
if
total
else
100
v_score
=
total_score
/
total
if
total
else
100
# 频率偏差评分
# 频率偏差评分
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
for
point_id
in
inline_point_ids
+
point_ids
:
for
point_id
in
inline_point_ids
+
point_ids
:
freq_mean
=
stats
.
get
(
point_id
,
{})
.
get
(
"freq_mean"
)
freq_mean
=
stats
.
get
(
point_id
,
{})
.
get
(
"freq_mean"
)
if
freq_mean
is
None
:
if
freq_mean
is
None
:
continue
continue
freq_dev
=
freq_mean
-
FREQ_STANDARD
freq_dev
=
freq_mean
-
FREQ_STANDARD
score
=
get_dev_score
(
dev_type
=
"freq"
,
cur
=
freq_dev
)
score
=
get_dev_score
(
dev_type
=
"freq"
,
cur
=
freq_dev
)
if
score
is
None
:
if
score
is
None
:
continue
continue
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
freq_score
=
total_score
/
total
if
total
else
100
freq_score
=
total_score
/
total
if
total
else
100
# 三相[电压]不平衡评分
# 三相[电压]不平衡评分
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
for
point_id
in
inline_point_ids
+
point_ids
:
for
point_id
in
inline_point_ids
+
point_ids
:
ubl_avg
=
stats
.
get
(
point_id
,
{})
.
get
(
"ubl_mean"
)
ubl_avg
=
stats
.
get
(
point_id
,
{})
.
get
(
"ubl_mean"
)
if
ubl_avg
is
None
:
if
ubl_avg
is
None
:
continue
continue
score
=
get_dev_score
(
dev_type
=
"ubl"
,
cur
=
ubl_avg
)
score
=
get_dev_score
(
dev_type
=
"ubl"
,
cur
=
ubl_avg
)
if
score
is
None
:
if
score
is
None
:
continue
continue
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
ubl_score
=
total_score
/
total
if
total
else
100
ubl_score
=
total_score
/
total
if
total
else
100
# 功率因数:有进线级功率因数时,只计算进线级功率因数
# 功率因数:有进线级功率因数时,只计算进线级功率因数
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
if
inline_point_ids
:
if
inline_point_ids
:
...
@@ -206,15 +206,15 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -206,15 +206,15 @@ async def load_health_radar(cid, param_point_id=None):
costtl_mean
=
stats
.
get
(
point_id
,
{})
.
get
(
"costtl_mean"
)
costtl_mean
=
stats
.
get
(
point_id
,
{})
.
get
(
"costtl_mean"
)
if
costtl_mean
is
None
:
if
costtl_mean
is
None
:
continue
continue
score
=
get_dev_score
(
dev_type
=
"costtl"
,
cur
=
costtl_mean
)
score
=
get_dev_score
(
dev_type
=
"costtl"
,
cur
=
costtl_mean
)
if
score
is
None
:
if
score
is
None
:
continue
continue
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
costtl_score
=
total_score
/
total
if
total
else
100
costtl_score
=
total_score
/
total
if
total
else
100
# (电压)谐波畸变率
# (电压)谐波畸变率
# 电压谐波畸变:只计算三表法计量点,如果所有监测点都是二表法,则取其他所有指标均值
# 电压谐波畸变:只计算三表法计量点,如果所有监测点都是二表法,则取其他所有指标均值
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
...
@@ -222,15 +222,15 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -222,15 +222,15 @@ async def load_health_radar(cid, param_point_id=None):
thdua_mean
=
stats
.
get
(
point_id
,
{})
.
get
(
"thdua_mean"
)
thdua_mean
=
stats
.
get
(
point_id
,
{})
.
get
(
"thdua_mean"
)
if
thdua_mean
is
None
:
if
thdua_mean
is
None
:
continue
continue
score
=
get_dev_score
(
dev_type
=
"thdu"
,
cur
=
thdua_mean
)
score
=
get_dev_score
(
dev_type
=
"thdu"
,
cur
=
thdua_mean
)
if
score
is
None
:
if
score
is
None
:
continue
continue
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
thdu_score
=
total_score
/
total
if
total
else
100
thdu_score
=
total_score
/
total
if
total
else
100
# 负载率
# 负载率
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
for
point_id
in
inline_point_ids
+
point_ids
:
for
point_id
in
inline_point_ids
+
point_ids
:
...
@@ -241,7 +241,7 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -241,7 +241,7 @@ async def load_health_radar(cid, param_point_id=None):
score
=
get_dev_score
(
dev_type
=
"lf"
,
cur
=
lf_mean
)
score
=
get_dev_score
(
dev_type
=
"lf"
,
cur
=
lf_mean
)
if
score
is
None
:
if
score
is
None
:
continue
continue
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
lf_score
=
total_score
/
total
if
total
else
100
lf_score
=
total_score
/
total
if
total
else
100
...
@@ -257,7 +257,7 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -257,7 +257,7 @@ async def load_health_radar(cid, param_point_id=None):
if
not
thdu_score
:
if
not
thdu_score
:
thdu_score
=
(
thdu_score
=
(
v_score
+
freq_score
+
ubl_score
+
costtl_score
+
lf_score
)
/
5.0
v_score
+
freq_score
+
ubl_score
+
costtl_score
+
lf_score
)
/
5.0
# 存入redis
# 存入redis
score_info
=
{
score_info
=
{
"v_score"
:
v_score
,
"v_score"
:
v_score
,
...
@@ -267,13 +267,13 @@ async def load_health_radar(cid, param_point_id=None):
...
@@ -267,13 +267,13 @@ async def load_health_radar(cid, param_point_id=None):
"thdu_score"
:
thdu_score
,
"thdu_score"
:
thdu_score
,
"lf_score"
:
lf_score
,
"lf_score"
:
lf_score
,
}
}
# now_ts = pendulum.now().int_timestamp
# now_ts = pendulum.now().int_timestamp
# tomorrow_ts = pendulum.tomorrow().int_timestamp
# tomorrow_ts = pendulum.tomorrow().int_timestamp
# exp_ts = tomorrow_ts - now_ts
# exp_ts = tomorrow_ts - now_ts
#
#
# await RedisClient().setex(redis_key, exp_ts, json.dumps(score_info))
# await RedisClient().setex(redis_key, exp_ts, json.dumps(score_info))
return
score_info
return
score_info
...
@@ -335,7 +335,7 @@ async def load_health_radar_new15(cid, param_point_id=None):
...
@@ -335,7 +335,7 @@ async def load_health_radar_new15(cid, param_point_id=None):
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
freq_score
=
total_score
/
total
if
total
else
100
freq_score
=
total_score
/
total
if
total
else
100
# 三相[电压]不平衡评分
# 三相[电压]不平衡评分
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
for
index
,
data
in
points_datas
.
items
():
for
index
,
data
in
points_datas
.
items
():
...
@@ -348,7 +348,7 @@ async def load_health_radar_new15(cid, param_point_id=None):
...
@@ -348,7 +348,7 @@ async def load_health_radar_new15(cid, param_point_id=None):
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
ubl_score
=
total_score
/
total
if
total
else
100
ubl_score
=
total_score
/
total
if
total
else
100
# 功率因数:有进线级功率因数时,只计算进线级功率因数
# 功率因数:有进线级功率因数时,只计算进线级功率因数
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
for
index
,
data
in
points_datas
.
items
():
for
index
,
data
in
points_datas
.
items
():
...
@@ -361,7 +361,7 @@ async def load_health_radar_new15(cid, param_point_id=None):
...
@@ -361,7 +361,7 @@ async def load_health_radar_new15(cid, param_point_id=None):
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
costtl_score
=
total_score
/
total
if
total
else
100
costtl_score
=
total_score
/
total
if
total
else
100
# (电压)谐波畸变率
# (电压)谐波畸变率
# 电压谐波畸变:只计算三表法计量点,如果所有监测点都是二表法,则取其他所有指标均值
# 电压谐波畸变:只计算三表法计量点,如果所有监测点都是二表法,则取其他所有指标均值
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
...
@@ -375,7 +375,7 @@ async def load_health_radar_new15(cid, param_point_id=None):
...
@@ -375,7 +375,7 @@ async def load_health_radar_new15(cid, param_point_id=None):
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
thdu_score
=
total_score
/
total
if
total
else
100
thdu_score
=
total_score
/
total
if
total
else
100
# 负载率
# 负载率
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
for
index
,
data
in
points_datas
.
items
():
for
index
,
data
in
points_datas
.
items
():
...
@@ -389,7 +389,7 @@ async def load_health_radar_new15(cid, param_point_id=None):
...
@@ -389,7 +389,7 @@ async def load_health_radar_new15(cid, param_point_id=None):
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
lf_score
=
total_score
/
total
if
total
else
100
lf_score
=
total_score
/
total
if
total
else
100
if
not
thdu_score
:
if
not
thdu_score
:
thdu_score
=
(
v_score
+
freq_score
+
ubl_score
+
costtl_score
+
thdu_score
=
(
v_score
+
freq_score
+
ubl_score
+
costtl_score
+
lf_score
)
/
5.0
lf_score
)
/
5.0
...
@@ -408,18 +408,18 @@ async def load_health_index(cid, point_id=None):
...
@@ -408,18 +408,18 @@ async def load_health_index(cid, point_id=None):
"""用电健康指数"""
"""用电健康指数"""
# score_info = await load_health_radar(cid, point_id)
# score_info = await load_health_radar(cid, point_id)
score_info
=
await
load_health_radar_new15
(
cid
,
point_id
)
score_info
=
await
load_health_radar_new15
(
cid
,
point_id
)
if
score_info
is
None
:
if
score_info
is
None
:
log
.
error
(
"load_health_index fail"
)
log
.
error
(
"load_health_index fail"
)
return
0
return
0
v_score
=
score_info
[
"v_score"
]
v_score
=
score_info
[
"v_score"
]
freq_score
=
score_info
[
"freq_score"
]
freq_score
=
score_info
[
"freq_score"
]
if
v_score
<=
60
or
freq_score
<=
60
:
if
v_score
<=
60
or
freq_score
<=
60
:
# 电压偏差/频率偏差评分,有一个低于60分,则整体健康指数为0
# 电压偏差/频率偏差评分,有一个低于60分,则整体健康指数为0
log
.
info
(
"v_score or freq_score less 60"
)
log
.
info
(
"v_score or freq_score less 60"
)
return
0
return
0
sub_dev
=
(
1
-
(
v_score
+
freq_score
)
/
200.0
)
*
20
sub_dev
=
(
1
-
(
v_score
+
freq_score
)
/
200.0
)
*
20
sub_lf
=
(
1
-
score_info
[
"lf_score"
]
/
100.0
)
*
20
sub_lf
=
(
1
-
score_info
[
"lf_score"
]
/
100.0
)
*
20
sub_costtl
=
(
1
-
score_info
[
"costtl_score"
]
/
100.0
)
*
20
sub_costtl
=
(
1
-
score_info
[
"costtl_score"
]
/
100.0
)
*
20
...
@@ -441,7 +441,7 @@ async def load_manage_health_radar(cids, recent_days=30):
...
@@ -441,7 +441,7 @@ async def load_manage_health_radar(cids, recent_days=30):
# if json_score:
# if json_score:
# score_info = json.loads(json_score)
# score_info = json.loads(json_score)
# return score_info
# return score_info
# 计算最近30天时间起始
# 计算最近30天时间起始
today
=
pendulum
.
today
()
today
=
pendulum
.
today
()
start_time
=
today
.
subtract
(
days
=
recent_days
)
.
format
(
"YYYY-MM-DD HH:mm:ss"
)
start_time
=
today
.
subtract
(
days
=
recent_days
)
.
format
(
"YYYY-MM-DD HH:mm:ss"
)
...
@@ -464,7 +464,7 @@ async def load_manage_health_radar(cids, recent_days=30):
...
@@ -464,7 +464,7 @@ async def load_manage_health_radar(cids, recent_days=30):
datas
=
await
conn
.
fetchall
(
sql
,
datas
=
await
conn
.
fetchall
(
sql
,
args
=
(
all_point_ids
,
start_time
,
end_time
))
args
=
(
all_point_ids
,
start_time
,
end_time
))
data_map
=
{
i
[
'pid'
]:
i
for
i
in
datas
}
data_map
=
{
i
[
'pid'
]:
i
for
i
in
datas
}
# 单独计算每个公司的健康指数
# 单独计算每个公司的健康指数
company_score_map
=
{}
company_score_map
=
{}
for
cid
in
cids
:
for
cid
in
cids
:
...
@@ -487,7 +487,7 @@ async def load_manage_health_radar(cids, recent_days=30):
...
@@ -487,7 +487,7 @@ async def load_manage_health_radar(cids, recent_days=30):
inline_point_ids
.
append
(
point_id
)
inline_point_ids
.
append
(
point_id
)
else
:
else
:
point_ids
.
append
(
point_id
)
point_ids
.
append
(
point_id
)
# 1. 电压偏差评分
# 1. 电压偏差评分
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
for
point_id
in
inline_point_ids
+
point_ids
:
for
point_id
in
inline_point_ids
+
point_ids
:
...
@@ -508,11 +508,11 @@ async def load_manage_health_radar(cids, recent_days=30):
...
@@ -508,11 +508,11 @@ async def load_manage_health_radar(cids, recent_days=30):
score
=
get_dev_score
(
dev_type
=
"v"
,
cur
=
v_dev
)
score
=
get_dev_score
(
dev_type
=
"v"
,
cur
=
v_dev
)
if
score
is
None
:
if
score
is
None
:
continue
continue
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
v_score
=
total_score
/
total
if
total
else
100
v_score
=
total_score
/
total
if
total
else
100
# 2. 频率偏差评分
# 2. 频率偏差评分
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
for
point_id
in
inline_point_ids
+
point_ids
:
for
point_id
in
inline_point_ids
+
point_ids
:
...
@@ -522,7 +522,7 @@ async def load_manage_health_radar(cids, recent_days=30):
...
@@ -522,7 +522,7 @@ async def load_manage_health_radar(cids, recent_days=30):
freq_mean
=
data_point_map
.
get
(
"freq_mean"
)
freq_mean
=
data_point_map
.
get
(
"freq_mean"
)
if
freq_mean
is
None
:
if
freq_mean
is
None
:
continue
continue
freq_dev
=
freq_mean
-
FREQ_STANDARD
freq_dev
=
freq_mean
-
FREQ_STANDARD
score
=
get_dev_score
(
dev_type
=
"freq"
,
cur
=
freq_dev
)
score
=
get_dev_score
(
dev_type
=
"freq"
,
cur
=
freq_dev
)
if
score
is
None
:
if
score
is
None
:
...
@@ -530,7 +530,7 @@ async def load_manage_health_radar(cids, recent_days=30):
...
@@ -530,7 +530,7 @@ async def load_manage_health_radar(cids, recent_days=30):
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
freq_score
=
total_score
/
total
if
total
else
100
freq_score
=
total_score
/
total
if
total
else
100
# 3. 三相[电压]不平衡评分
# 3. 三相[电压]不平衡评分
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
for
point_id
in
inline_point_ids
+
point_ids
:
for
point_id
in
inline_point_ids
+
point_ids
:
...
@@ -546,7 +546,7 @@ async def load_manage_health_radar(cids, recent_days=30):
...
@@ -546,7 +546,7 @@ async def load_manage_health_radar(cids, recent_days=30):
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
ubl_score
=
total_score
/
total
if
total
else
100
ubl_score
=
total_score
/
total
if
total
else
100
# 4. 功率因数:有进线级功率因数时,只计算进线级功率因数
# 4. 功率因数:有进线级功率因数时,只计算进线级功率因数
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
if
inline_point_ids
:
if
inline_point_ids
:
...
@@ -566,7 +566,7 @@ async def load_manage_health_radar(cids, recent_days=30):
...
@@ -566,7 +566,7 @@ async def load_manage_health_radar(cids, recent_days=30):
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
costtl_score
=
total_score
/
total
if
total
else
100
costtl_score
=
total_score
/
total
if
total
else
100
# 4.(电压)谐波畸变率
# 4.(电压)谐波畸变率
# 电压谐波畸变:只计算三表法计量点,如果所有监测点都是二表法,则取其他所有指标均值
# 电压谐波畸变:只计算三表法计量点,如果所有监测点都是二表法,则取其他所有指标均值
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
...
@@ -583,7 +583,7 @@ async def load_manage_health_radar(cids, recent_days=30):
...
@@ -583,7 +583,7 @@ async def load_manage_health_radar(cids, recent_days=30):
total_score
+=
score
total_score
+=
score
total
+=
1
total
+=
1
thdu_score
=
total_score
/
total
if
total
else
100
thdu_score
=
total_score
/
total
if
total
else
100
# 5. 负载率
# 5. 负载率
total
,
total_score
=
0
,
0
total
,
total_score
=
0
,
0
for
point_id
in
inline_point_ids
+
point_ids
:
for
point_id
in
inline_point_ids
+
point_ids
:
...
@@ -614,7 +614,7 @@ async def load_manage_health_radar(cids, recent_days=30):
...
@@ -614,7 +614,7 @@ async def load_manage_health_radar(cids, recent_days=30):
if
not
thdu_score
:
if
not
thdu_score
:
thdu_score
=
(
thdu_score
=
(
v_score
+
freq_score
+
ubl_score
+
costtl_score
+
lf_score
)
/
5.0
v_score
+
freq_score
+
ubl_score
+
costtl_score
+
lf_score
)
/
5.0
company_score_map
[
cid
]
=
{
company_score_map
[
cid
]
=
{
"v_score"
:
v_score
,
"v_score"
:
v_score
,
"freq_score"
:
freq_score
,
"freq_score"
:
freq_score
,
...
@@ -639,7 +639,7 @@ async def load_manage_health_index(company_score_info):
...
@@ -639,7 +639,7 @@ async def load_manage_health_index(company_score_info):
log
.
error
(
f
"cid = {cid}load_health_index fail"
)
log
.
error
(
f
"cid = {cid}load_health_index fail"
)
company_index_map
[
cid
]
=
0
company_index_map
[
cid
]
=
0
continue
continue
v_score
=
score_info
[
"v_score"
]
v_score
=
score_info
[
"v_score"
]
freq_score
=
score_info
[
"freq_score"
]
freq_score
=
score_info
[
"freq_score"
]
if
v_score
<=
60
or
freq_score
<=
60
:
if
v_score
<=
60
or
freq_score
<=
60
:
...
@@ -647,7 +647,7 @@ async def load_manage_health_index(company_score_info):
...
@@ -647,7 +647,7 @@ async def load_manage_health_index(company_score_info):
log
.
info
(
f
"cid = {cid} v_score or freq_score less 60"
)
log
.
info
(
f
"cid = {cid} v_score or freq_score less 60"
)
company_index_map
[
cid
]
=
0
company_index_map
[
cid
]
=
0
continue
continue
sub_dev
=
(
1
-
(
v_score
+
freq_score
)
/
200.0
)
*
20
sub_dev
=
(
1
-
(
v_score
+
freq_score
)
/
200.0
)
*
20
sub_lf
=
(
1
-
score_info
[
"lf_score"
]
/
100.0
)
*
20
sub_lf
=
(
1
-
score_info
[
"lf_score"
]
/
100.0
)
*
20
sub_costtl
=
(
1
-
score_info
[
"costtl_score"
]
/
100.0
)
*
20
sub_costtl
=
(
1
-
score_info
[
"costtl_score"
]
/
100.0
)
*
20
...
...
unify_api/modules/device_cloud/procedures/mqtt_helper.py
View file @
4af81566
import
pendulum
import
pendulum
from
unify_api.modules.common.dao.common_dao
import
(
from
pot_libs.logger
import
log
get_point_monitor_dao
,
get_location_monitor_dao
from
unify_api.modules.common.dao.common_dao
import
mid_by_pid
,
meter_by_mid
,
\
)
meter_param_by_mid
,
change_sensor_by_location
,
get_point_monitor_dao
,
\
get_location_monitor_dao
from
uuid
import
uuid4
from
uuid
import
uuid4
async
def
get_point_soe_config
(
event_data
,
with_params
=
False
):
async
def
get_point_soe_config
(
event_data
,
with_params
=
False
):
"""
with_params: 用于同步配置参数信息,保证adio事件可以得到正确的数值
"""
point_id
=
event_data
.
get
(
'point_id'
)
event_settings
=
{
k
:
v
for
k
,
v
in
event_data
.
items
()
if
k
in
[
'threshold'
,
'duration'
,
'enable'
]}
# 根据pid获取mid
mid_dic
=
await
mid_by_pid
(
point_id
)
mid
=
mid_dic
.
get
(
"mid"
)
if
mid
is
None
:
log
.
info
(
f
'=======no mid of point id: {point_id}'
)
return
None
,
None
meter_dic
=
await
meter_by_mid
(
mid
)
sid
=
meter_dic
.
get
(
"sid"
)
meter_sn
=
meter_dic
.
get
(
"meter_no"
)
config
=
{
'soe'
:
{
"electric"
:
{
meter_sn
:
{
event_data
[
'event_type'
]:
event_settings
}}}
}
if
with_params
:
params
=
await
meter_param_by_mid
(
mid
)
params
=
{
k
:
v
for
k
,
v
in
params
.
items
()
if
v
is
not
None
}
params
[
'point_id'
]
=
point_id
config
[
'params'
]
=
{
'electric'
:
{
meter_sn
:
params
}}
return
sid
,
config
async
def
get_point_soe_config_new15
(
event_data
,
with_params
=
False
):
point_id
=
event_data
.
get
(
'point_id'
)
point_id
=
event_data
.
get
(
'point_id'
)
event_settings
=
{
k
:
v
for
k
,
v
in
event_data
.
items
()
if
k
in
[
event_settings
=
{
k
:
v
for
k
,
v
in
event_data
.
items
()
if
k
in
[
'threshold'
,
'duration'
,
'enable'
'threshold'
,
'duration'
,
'enable'
...
@@ -50,7 +16,9 @@ async def get_point_soe_config_new15(event_data, with_params=False):
...
@@ -50,7 +16,9 @@ async def get_point_soe_config_new15(event_data, with_params=False):
config
=
{
config
=
{
'soe'
:
{
'soe'
:
{
"electric"
:
{
"electric"
:
{
meter_sn
:
{
event_data
[
'event_type'
]:
event_settings
}}}
meter_sn
:
{
event_data
[
'event_type'
]:
event_settings
}
}
}
}
}
if
with_params
:
if
with_params
:
keys_li
=
[
"ctr"
,
"ptr"
,
"ctnum"
,
"vc"
,
"tc"
,
"imax"
]
keys_li
=
[
"ctr"
,
"ptr"
,
"ctnum"
,
"vc"
,
"tc"
,
"imax"
]
...
@@ -62,29 +30,6 @@ async def get_point_soe_config_new15(event_data, with_params=False):
...
@@ -62,29 +30,6 @@ async def get_point_soe_config_new15(event_data, with_params=False):
async
def
get_location_soe_config
(
event
,
with_params
):
async
def
get_location_soe_config
(
event
,
with_params
):
location_id
=
event
.
get
(
'location_id'
)
event_settings
=
{
k
:
v
for
k
,
v
in
event
.
items
()
if
k
in
[
'threshold'
,
'duration'
,
'enable'
]}
try
:
sensor_dic
=
await
change_sensor_by_location
(
location_id
)
sid
=
sensor_dic
.
get
(
"sid"
)
field
=
sensor_dic
.
get
(
"field"
)
except
:
log
.
info
(
f
'=======no sid of location: {location_id}'
)
return
None
,
None
if
field
==
"residual_current"
:
config
=
{
'soe'
:
{
"adio"
:
{
event
[
'event_type'
]:
event_settings
}}}
else
:
config
=
{
'soe'
:
{
"adio"
:
{
field
:
{
event
[
'event_type'
]:
event_settings
}}}}
if
with_params
:
config
[
'params'
]
=
{
'adio'
:
{
field
:
{
'location_id'
:
location_id
}}}
return
sid
,
config
async
def
get_location_soe_config_new15
(
event
,
with_params
):
location_id
=
event
.
get
(
'location_id'
)
location_id
=
event
.
get
(
'location_id'
)
event_settings
=
{
k
:
v
for
k
,
v
in
event
.
items
()
if
k
in
[
event_settings
=
{
k
:
v
for
k
,
v
in
event
.
items
()
if
k
in
[
'threshold'
,
'duration'
,
'enable'
'threshold'
,
'duration'
,
'enable'
...
@@ -110,24 +55,19 @@ async def change_param_to_config(req_json, method):
...
@@ -110,24 +55,19 @@ async def change_param_to_config(req_json, method):
sid
,
config
=
None
,
None
sid
,
config
=
None
,
None
point_id
=
req_json
.
get
(
"point_id"
)
point_id
=
req_json
.
get
(
"point_id"
)
if
point_id
is
not
None
:
if
point_id
is
not
None
:
# sid, config = await get_point_soe_config(req_json, with_params=True)
sid
,
config
=
await
get_point_soe_config
(
req_json
,
with_params
=
True
)
sid
,
config
=
await
get_point_soe_config_new15
(
req_json
,
with_params
=
True
)
location_id
=
req_json
.
get
(
'location_id'
)
location_id
=
req_json
.
get
(
'location_id'
)
if
location_id
is
not
None
:
if
location_id
is
not
None
:
# sid, config = await get_location_soe_config(req_json,
sid
,
config
=
await
get_location_soe_config
(
req_json
,
with_params
=
True
)
# with_params=True)
sid
,
config
=
await
get_location_soe_config_new15
(
req_json
,
with_params
=
True
)
request_data
=
{}
request_data
=
{}
if
sid
:
if
sid
:
request_id
=
str
(
uuid4
())
request_id
=
str
(
uuid4
())
request_data
=
dict
(
request_data
=
dict
(
request_id
=
request_id
,
request_id
=
request_id
,
time
=
pendulum
.
now
()
.
to_datetime_string
(),
time
=
pendulum
.
now
()
.
to_datetime_string
(),
method
=
method
,
method
=
method
,
sid
=
sid
,
data
=
config
)
sid
=
sid
,
data
=
config
)
return
request_data
return
request_data
...
@@ -142,12 +82,11 @@ async def switch_control_param_to_config(sid, field, switch,
...
@@ -142,12 +82,11 @@ async def switch_control_param_to_config(sid, field, switch,
if
switch
==
"00"
:
if
switch
==
"00"
:
switch
=
"10"
switch
=
"10"
request_id
=
str
(
uuid4
())
request_id
=
str
(
uuid4
())
request_data
=
dict
(
request_data
=
dict
(
request_id
=
request_id
,
request_id
=
request_id
,
time
=
pendulum
.
now
()
.
to_datetime_string
(),
time
=
pendulum
.
now
()
.
to_datetime_string
(),
method
=
method
,
method
=
method
,
sid
=
sid
,
sid
=
sid
,
data
=
{
'command'
:
command
,
data
=
{
'command'
:
command
,
'params'
:
{
'field'
:
field
,
'value'
:
switch
}}
'params'
:
{
'field'
:
field
,
'value'
:
switch
}}
)
)
return
request_data
return
request_data
unify_api/modules/device_mqtt/procedures/mqtt_helper.py
View file @
4af81566
import
pendulum
import
pendulum
from
unify_api.modules.common.dao.common_dao
import
(
from
pot_libs.logger
import
log
get_point_monitor_dao
,
get_location_monitor_dao
from
unify_api.modules.common.dao.common_dao
import
mid_by_pid
,
meter_by_mid
,
\
)
meter_param_by_mid
,
change_sensor_by_location
from
uuid
import
uuid4
from
uuid
import
uuid4
async
def
get_point_soe_config
(
event_data
,
with_params
=
False
):
async
def
get_point_soe_config
(
event_data
,
with_params
=
False
):
"""
with_params: 用于同步配置参数信息,保证adio事件可以得到正确的数值
"""
point_id
=
event_data
.
get
(
'point_id'
)
point_id
=
event_data
.
get
(
'point_id'
)
event_settings
=
{
k
:
v
for
k
,
v
in
event_data
.
items
()
if
k
in
[
event_settings
=
{
k
:
v
for
k
,
v
in
event_data
.
items
()
if
k
in
[
'threshold'
,
'duration'
,
'enable'
'threshold'
,
'duration'
,
'enable'
]}
]}
# 根据pid获取mid
datas
=
await
get_point_monitor_dao
(
point_id
)
mid_dic
=
await
mid_by_pid
(
point_id
)
sid
=
datas
.
get
(
"sid"
)
mid
=
mid_dic
.
get
(
"mid"
)
meter_sn
=
datas
.
get
(
"meter_no"
)
if
mid
is
None
:
log
.
info
(
f
'=======no mid of point id: {point_id}'
)
return
None
,
None
meter_dic
=
await
meter_by_mid
(
mid
)
sid
=
meter_dic
.
get
(
"sid"
)
meter_sn
=
meter_dic
.
get
(
"meter_no"
)
config
=
{
config
=
{
'soe'
:
{
'soe'
:
{
"electric"
:
{
"electric"
:
{
meter_sn
:
{
event_data
[
'event_type'
]:
event_settings
}}
meter_sn
:
{
event_data
[
'event_type'
]:
event_settings
}}
}
}
}
}
if
with_params
:
if
with_params
:
params
=
await
meter_param_by_mid
(
mid
)
keys_li
=
[
"ctr"
,
"ptr"
,
"ctnum"
,
"vc"
,
"tc"
,
"imax"
]
params
=
{
k
:
v
for
k
,
v
in
params
.
items
()
if
v
is
not
None
}
params
=
{
k
:
v
for
k
,
v
in
datas
.
items
()
if
k
in
keys_li
and
(
v
is
not
None
)}
params
[
'point_id'
]
=
point_id
params
[
'point_id'
]
=
point_id
config
[
'params'
]
=
{
'electric'
:
{
meter_sn
:
params
}}
config
[
'params'
]
=
{
'electric'
:
{
meter_sn
:
params
}}
return
sid
,
config
return
sid
,
config
...
@@ -43,14 +32,9 @@ async def get_location_soe_config(event, with_params):
...
@@ -43,14 +32,9 @@ async def get_location_soe_config(event, with_params):
event_settings
=
{
k
:
v
for
k
,
v
in
event
.
items
()
if
k
in
[
event_settings
=
{
k
:
v
for
k
,
v
in
event
.
items
()
if
k
in
[
'threshold'
,
'duration'
,
'enable'
'threshold'
,
'duration'
,
'enable'
]}
]}
try
:
datas
=
await
get_location_monitor_dao
(
location_id
)
sensor_dic
=
await
change_sensor_by_location
(
location_id
)
sid
=
datas
.
get
(
"sid"
)
sid
=
sensor_dic
.
get
(
"sid"
)
field
=
datas
.
get
(
"ad_field"
)
field
=
sensor_dic
.
get
(
"field"
)
except
:
log
.
info
(
f
'=======no sid of location: {location_id}'
)
return
None
,
None
if
field
==
"residual_current"
:
if
field
==
"residual_current"
:
config
=
{
'soe'
:
{
"adio"
:
{
event
[
'event_type'
]:
event_settings
}}}
config
=
{
'soe'
:
{
"adio"
:
{
event
[
'event_type'
]:
event_settings
}}}
else
:
else
:
...
...
unify_api/modules/elec_charge/procedures/elec_statis_proxy_pds.py
View file @
4af81566
from
pot_libs.es_util.es_utils
import
EsUtil
from
pot_libs.logger
import
log
from
pot_libs.mysql_util.mysql_util
import
MysqlUtil
from
pot_libs.mysql_util.mysql_util
import
MysqlUtil
from
unify_api.constants
import
COMPANY_15MIN_POWER
,
SLOTS
,
SLOTS_15MIN
from
unify_api.constants
import
SLOTS
,
SLOTS_15MIN
from
unify_api.modules.elec_charge.components.elec_statistics_cps
import
\
from
unify_api.modules.elec_charge.components.elec_statistics_cps
import
\
SlotValue
SlotValue
from
unify_api.modules.elec_charge.dao.elec_charge_dao
import
\
from
unify_api.modules.elec_charge.dao.elec_charge_dao
import
\
power_charge_p_aggs
power_charge_p_aggs
from
unify_api.utils.common_utils
import
round_2
from
unify_api.utils.common_utils
import
round_2
from
unify_api.utils.es_query_body
import
EsQueryBody
,
es_process
,
\
from
unify_api.utils.es_query_body
import
es_process
,
sql_time_process
sql_time_process
from
unify_api.utils.time_format
import
time_pick_transf
from
unify_api.utils.time_format
import
time_pick_transf
async
def
proxy_today_yesterday_p
(
cid_list
,
start
,
end
):
async
def
proxy_today_yesterday_load
(
cid_list
,
start
,
end
):
"""proxy首页今日和昨日负荷"""
index
=
COMPANY_15MIN_POWER
terms
=
{
"cid"
:
cid_list
}
# 1.构造query_body
query
=
EsQueryBody
(
terms
=
terms
,
start
=
start
,
end
=
end
,
date_key
=
"quarter_time"
,
size
=
0
)
query_body
=
query
.
query
()
query_body
[
"aggs"
]
=
{
"quarter_time"
:
{
"date_histogram"
:
{
"field"
:
"quarter_time"
,
"interval"
:
"15m"
,
"time_zone"
:
"+08:00"
,
"format"
:
"yyyy-MM-dd HH:mm:ss"
},
"aggs"
:
{
"p"
:
{
"stats"
:
{
"field"
:
"p"
}
}
}
}
}
log
.
info
(
index
+
f
"====={query_body}"
)
# 2.获取slots
intervel
,
slots
=
time_pick_transf
(
start
,
end
)
# 3. 查询es
async
with
EsUtil
()
as
es
:
es_re
=
await
es
.
search_origin
(
body
=
query_body
,
index
=
index
)
es_re
=
es_re
[
"aggregations"
][
"quarter_time"
][
"buckets"
]
if
not
es_re
:
return
SlotValue
(
slots
=
slots
,
value
=
[])
# 4.为了es结果和slots对应
es_re
=
es_process
(
es_re
,
fmat
=
"HH:mm"
)
sv
=
SlotValue
()
# 今日负荷对象
sv
.
slots
=
slots
tmp_list
=
[]
# 5.拼接返回
for
slot
in
slots
:
if
slot
in
es_re
:
# 1.每个时间点,电量信息
value
=
es_re
[
slot
]
.
get
(
"p"
)
.
get
(
"sum"
)
# 值为0是正常数据
if
value
==
0
:
tmp_list
.
append
(
0.0
)
else
:
tmp_list
.
append
(
value
or
""
)
else
:
tmp_list
.
append
(
""
)
sv
.
value
=
tmp_list
return
sv
async
def
proxy_today_yesterday_p_new15
(
cid_list
,
start
,
end
):
"""proxy首页今日和昨日负荷"""
"""proxy首页今日和昨日负荷"""
sql
=
f
"""
sql
=
f
"""
select create_time,sum(p) as p from company_15min_power
select create_time,sum(p) as p from company_15min_power
...
@@ -145,14 +87,14 @@ async def power_charge_p_proxy(cid_list, start, end, date_type, interval):
...
@@ -145,14 +87,14 @@ async def power_charge_p_proxy(cid_list, start, end, date_type, interval):
time_key
=
"create_time"
)
# 为了es结果和slots对应
time_key
=
"create_time"
)
# 为了es结果和slots对应
kwh_24
,
charge_24
,
p_24
,
price_24
=
by_slots
(
slots_96
,
es_re_96_dic
)
kwh_24
,
charge_24
,
p_24
,
price_24
=
by_slots
(
slots_96
,
es_re_96_dic
)
# 96个点,工厂电量电费
# 96个点,工厂电量电费
# 2. 24个点数据
# 2. 24个点数据
slots_24
=
SLOTS
[
date_type
]
slots_24
=
SLOTS
[
date_type
]
es_re_24
=
await
power_charge_p_aggs
(
start
,
end
,
cid_list
,
"hour"
)
es_re_24
=
await
power_charge_p_aggs
(
start
,
end
,
cid_list
,
"hour"
)
es_re_24_dic
=
es_process
(
es_re_24
,
fmat
=
"HH:mm"
,
es_re_24_dic
=
es_process
(
es_re_24
,
fmat
=
"HH:mm"
,
time_key
=
"create_time"
)
# 为了es结果和slots对应
time_key
=
"create_time"
)
# 为了es结果和slots对应
kwh_24
,
charge_24
,
p_24
,
price_24
=
by_slots
(
slots_24
,
es_re_24_dic
)
kwh_24
,
charge_24
,
p_24
,
price_24
=
by_slots
(
slots_24
,
es_re_24_dic
)
# elif date_type == "month":
# elif date_type == "month":
# intervel, slots = time_pick_transf(start, end)
# intervel, slots = time_pick_transf(start, end)
# es_re = es_process(es_re, fmat="MM-DD") # 为了es结果和slots对应
# es_re = es_process(es_re, fmat="MM-DD") # 为了es结果和slots对应
unify_api/modules/elec_charge/views/elec_statis_proxy.py
View file @
4af81566
...
@@ -20,7 +20,7 @@ from unify_api.modules.elec_charge.dao.elec_charge_dao import \
...
@@ -20,7 +20,7 @@ from unify_api.modules.elec_charge.dao.elec_charge_dao import \
power_charge_p_aggs
,
power_charge_p_cid_aggs
,
histogram_aggs_points
,
\
power_charge_p_aggs
,
power_charge_p_cid_aggs
,
histogram_aggs_points
,
\
power_charge_p_point_aggs
power_charge_p_point_aggs
from
unify_api.modules.elec_charge.procedures.elec_statis_proxy_pds
import
\
from
unify_api.modules.elec_charge.procedures.elec_statis_proxy_pds
import
\
proxy_today_yesterday_
p_new15
,
by_slots
proxy_today_yesterday_
load
,
by_slots
from
unify_api.modules.elec_charge.common.utils
import
aver_price
,
\
from
unify_api.modules.elec_charge.common.utils
import
aver_price
,
\
load_power_charge
load_power_charge
from
unify_api.utils.common_utils
import
process_es_data
from
unify_api.utils.common_utils
import
process_es_data
...
@@ -56,9 +56,9 @@ async def post_power_statis_proxy(req, body: StatisProxyReq) -> PcStatiResp:
...
@@ -56,9 +56,9 @@ async def post_power_statis_proxy(req, body: StatisProxyReq) -> PcStatiResp:
end
,
date_type
)
end
,
date_type
)
# 需要增加15min电量电费, 渠道版首页不需要下载,暂时去掉
# 需要增加15min电量电费, 渠道版首页不需要下载,暂时去掉
# 今日/昨日负荷曲线
# 今日/昨日负荷曲线
today_p
=
await
proxy_today_yesterday_
p_new15
(
cid_list
,
start
,
end
)
today_p
=
await
proxy_today_yesterday_
load
(
cid_list
,
start
,
end
)
ysd_start
,
ysd_end
=
last_time_str
(
start
,
end
,
"day"
)
ysd_start
,
ysd_end
=
last_time_str
(
start
,
end
,
"day"
)
yesterday_p
=
await
proxy_today_yesterday_
p_new15
(
cid_list
,
ysd_start
,
yesterday_p
=
await
proxy_today_yesterday_
load
(
cid_list
,
ysd_start
,
ysd_end
)
ysd_end
)
return
PcStatiResp
(
kwh
=
kwh_sv
,
charge
=
charge_sv
,
today_p
=
today_p
,
return
PcStatiResp
(
kwh
=
kwh_sv
,
charge
=
charge_sv
,
today_p
=
today_p
,
yesterday_p
=
yesterday_p
)
yesterday_p
=
yesterday_p
)
...
@@ -97,7 +97,7 @@ async def post_power_statis_proxy(req, body: StatisProxyReq) -> PcStatiResp:
...
@@ -97,7 +97,7 @@ async def post_power_statis_proxy(req, body: StatisProxyReq) -> PcStatiResp:
kwh_sv
,
charge_sv
=
await
load_power_charge
(
cid_list
,
point_id
,
kwh_sv
,
charge_sv
=
await
load_power_charge
(
cid_list
,
point_id
,
start
,
end
,
date_type
)
start
,
end
,
date_type
)
# 负荷曲线
# 负荷曲线
this_p
=
await
proxy_today_yesterday_
p_new15
(
cid_list
,
start
,
this_p
=
await
proxy_today_yesterday_
load
(
cid_list
,
start
,
end
)
end
)
# 需要增加15min电量电费, 渠道版首页不需要下载,暂时去掉
# 需要增加15min电量电费, 渠道版首页不需要下载,暂时去掉
return
PcStatiResp
(
kwh
=
kwh_sv
,
charge
=
charge_sv
,
today_p
=
this_p
)
return
PcStatiResp
(
kwh
=
kwh_sv
,
charge
=
charge_sv
,
today_p
=
this_p
)
...
@@ -365,9 +365,9 @@ async def post_power_statist_opt(req, body: PopReq) -> PcStatiResp:
...
@@ -365,9 +365,9 @@ async def post_power_statist_opt(req, body: PopReq) -> PcStatiResp:
date_type
)
date_type
)
# 需要增加15min电量电费, 渠道版首页不需要下载,暂时去掉
# 需要增加15min电量电费, 渠道版首页不需要下载,暂时去掉
# 今日/昨日负荷曲线
# 今日/昨日负荷曲线
today_p
=
await
proxy_today_yesterday_
p_new15
(
cid_list
,
start
,
end
)
today_p
=
await
proxy_today_yesterday_
load
(
cid_list
,
start
,
end
)
ysd_start
,
ysd_end
=
last_time_str
(
start
,
end
,
"day"
)
ysd_start
,
ysd_end
=
last_time_str
(
start
,
end
,
"day"
)
yesterday_p
=
await
proxy_today_yesterday_
p_new15
(
cid_list
,
yesterday_p
=
await
proxy_today_yesterday_
load
(
cid_list
,
ysd_start
,
ysd_start
,
ysd_end
)
ysd_end
)
return
PcStatiResp
(
kwh
=
kwh_sv
,
charge
=
charge_sv
,
today_p
=
today_p
,
return
PcStatiResp
(
kwh
=
kwh_sv
,
charge
=
charge_sv
,
today_p
=
today_p
,
...
...
unify_api/modules/home_page/procedures/count_info_pds.py
View file @
4af81566
...
@@ -37,61 +37,7 @@ from unify_api.utils.taos_new import parse_td_columns, get_td_table_name, \
...
@@ -37,61 +37,7 @@ from unify_api.utils.taos_new import parse_td_columns, get_td_table_name, \
td3_tbl_compate
,
get_td_engine_data
td3_tbl_compate
,
get_td_engine_data
async
def
other_info
(
company_id
):
async
def
other_info
(
cid
):
"""
今日报警数和累计安全运行天数,报警数
"""
alarm_sql
=
f
"""
SELECT
DATE(pevent.event_datetime) event_date,
COUNT(*) event_count
FROM
point_1min_event pevent
WHERE
cid =
%
s
GROUP BY
DATE(pevent.event_datetime)
"""
now_time
=
datetime
.
now
()
# 获取到工厂安装时间create_time
async
with
MysqlUtil
()
as
conn
:
company_sql
=
"select create_time from company where cid =
%
s"
alarm_data
=
await
conn
.
fetchall
(
alarm_sql
,
(
company_id
,))
company
=
await
conn
.
fetchone
(
company_sql
,
(
company_id
,))
create_time_timestamp
=
company
[
"create_time"
]
create_time
=
datetime
.
fromtimestamp
(
create_time_timestamp
)
today_alarm_count
=
0
alarm_count
=
0
if
not
alarm_data
:
log
.
warn
(
"No alarm data
%
s"
%
(
company_id
)
)
# 1. 增加逻辑,新增工厂如果还没有事件产生
# 系统安全运行天数: 当前时间 - 工厂安装时间 + 1
safe_run_days
=
(
now_time
-
create_time
)
.
days
+
1
return
today_alarm_count
,
safe_run_days
,
alarm_count
# 5. 构造返回
# 如果每天都有报警, 防止安全运行天数-1天, 所以total_days +2
total_days
=
(
now_time
-
create_time
)
.
days
+
2
has_alarm_days
=
0
for
data
in
alarm_data
:
create_time
.
strftime
(
"
%
Y-
%
m-
%
d"
)
if
data
[
"event_date"
]
.
strftime
(
"
%
Y-
%
m-
%
d"
)
==
str
(
now_time
)[:
10
]:
today_alarm_count
+=
data
[
"event_count"
]
if
data
[
"event_count"
]
!=
0
:
# 没有报警,看做是安全运行了,统计累计安全运行的天数
has_alarm_days
+=
1
alarm_count
+=
data
[
"event_count"
]
safe_run_days
=
total_days
-
has_alarm_days
log
.
info
(
f
"today_alarm_count={today_alarm_count} safe_run_days={safe_run_days}"
)
return
today_alarm_count
,
safe_run_days
,
alarm_count
async
def
other_info_new15
(
cid
):
today_alarm_count
,
alarm_count
,
has_alarm_days
=
0
,
0
,
0
today_alarm_count
,
alarm_count
,
has_alarm_days
=
0
,
0
,
0
sql
=
"SELECT DATE_FORMAT(event_datetime,'
%%
Y-
%%
m-
%%
d') event_date, "
\
sql
=
"SELECT DATE_FORMAT(event_datetime,'
%%
Y-
%%
m-
%%
d') event_date, "
\
"count(id) doc_count FROM `point_1min_event` where cid=
%
s "
\
"count(id) doc_count FROM `point_1min_event` where cid=
%
s "
\
...
...
unify_api/modules/home_page/service/health_index_service.py
View file @
4af81566
import
json
import
time
import
time
import
re
import
pendulum
import
pendulum
from
unify_api.modules.electric.dao.electric_dao
import
\
from
unify_api.modules.electric.dao.electric_dao
import
\
get_elec_mtid_sid_by_cid
get_elec_mtid_sid_by_cid
from
unify_api.modules.common.dao.common_dao
import
monitor_by_cid
from
unify_api.utils.common_utils
import
round_2
from
unify_api.utils.common_utils
import
round_2
from
pot_libs.logger
import
log
from
pot_libs.logger
import
log
from
pot_libs.settings
import
SETTING
from
pot_libs.settings
import
SETTING
from
pot_libs.aredis_util.aredis_utils
import
RedisUtils
from
unify_api.modules.electric.procedures.electric_util
import
get_wiring_type
from
unify_api.modules.home_page.procedures
import
point_inlines
from
unify_api.modules.home_page.procedures.dev_grade
import
get_dev_grade
from
unify_api.modules.home_page.procedures.dev_grade
import
get_dev_grade
from
unify_api.utils
import
time_format
from
unify_api.utils
import
time_format
from
unify_api.modules.electric.views.electric
import
(
from
unify_api.constants
import
REAL_EXP_TIME
METERDATA_CURRENT_KEY
,
from
pot_libs.utils.exc_util
import
ParamException
,
BusinessException
METERDATA_CURRENT_HR_KEY
,
)
from
unify_api.constants
import
VOLTAGE_STANDARD
,
REAL_EXP_TIME
,
\
FREQ_STANDARD
,
Product
from
pot_libs.utils.exc_util
import
ParamException
,
DBException
,
\
BusinessException
from
unify_api.modules.home_page.components.health_index
import
\
from
unify_api.modules.home_page.components.health_index
import
\
HealthCtlRateRes
HealthCtlRateRes
from
unify_api.modules.zhiwei_u.dao.warning_operations_dao
import
\
from
unify_api.modules.zhiwei_u.dao.warning_operations_dao
import
\
select_point_dao
select_point_dao
from
unify_api.modules.common.service.td_engine_service
import
\
from
unify_api.modules.common.service.td_engine_service
import
\
get_td_engine_data
get_td_engine_data
...
@@ -33,155 +20,7 @@ from unify_api.utils.taos_new import parse_td_columns, td3_tbl_compate, \
...
@@ -33,155 +20,7 @@ from unify_api.utils.taos_new import parse_td_columns, td3_tbl_compate, \
get_td_table_name
get_td_table_name
async
def
health_ctl_rate_service
(
cid
):
async
def
health_ctl_rate_srv
(
cid
):
if
cid
<=
0
:
log
.
error
(
"param error"
)
raise
ParamException
(
message
=
"参数错误, cid参数必须是一个正整数!"
)
# 获取工厂所有监测点数据
point_infos
=
await
point_inlines
.
get_all_points
(
cid
)
if
not
point_infos
:
log
.
error
(
"cid:
%
s no point data"
%
cid
)
raise
BusinessException
(
message
=
"工厂没有任何监测点!"
)
point_ids
=
point_infos
.
keys
()
stats
=
{
"lf"
:
0
,
"costtl"
:
0
,
"freq_dev"
:
0
,
"thdu"
:
0
,
"v_dev"
:
0
,
"ubl"
:
0
}
now_ts
=
int
(
time
.
time
())
real_tt
=
now_ts
valid_mids
=
[]
total
=
0
for
point_id
in
point_ids
:
ctnum
,
mid
=
await
get_wiring_type
(
point_id
)
if
not
mid
:
# 换表: point_id 有效, mid(拆掉)为None的情况
log
.
warn
(
f
"cid={ctnum} point_id={point_id} 已经换表了"
)
continue
valid_mids
.
append
(
mid
)
try
:
res
=
None
result
=
await
RedisUtils
()
.
hget
(
METERDATA_CURRENT_KEY
,
mid
)
result2
=
await
RedisUtils
()
.
hget
(
METERDATA_CURRENT_HR_KEY
,
mid
)
if
result
and
result2
:
res
=
json
.
loads
(
result
)
res2
=
json
.
loads
(
result2
)
real1_tt
=
res
.
get
(
"timestamp"
)
real_tt
=
res2
.
get
(
"timestamp"
)
if
(
real1_tt
and
real_tt
and
now_ts
-
real1_tt
<=
REAL_EXP_TIME
and
now_ts
-
real_tt
<=
REAL_EXP_TIME
):
for
k
in
res2
.
keys
():
if
not
k
in
res
.
keys
():
res
[
k
]
=
res2
[
k
]
else
:
log
.
info
(
"1 realtime_power_qual of mid
%
s is expired."
%
mid
)
continue
elif
result2
:
res
=
json
.
loads
(
result2
)
real_tt
=
res
.
get
(
"timestamp"
)
if
real_tt
and
now_ts
-
real_tt
<=
REAL_EXP_TIME
:
res
=
res
else
:
log
.
info
(
"2 realtime_power_qual of mid
%
s is expired."
%
mid
)
continue
elif
result
:
res
=
json
.
loads
(
result
)
real_tt
=
res
.
get
(
"timestamp"
)
if
real_tt
and
now_ts
-
real_tt
<=
REAL_EXP_TIME
:
res
=
res
else
:
log
.
info
(
"3 realtime_power_qual of mid
%
s is expired."
%
mid
)
continue
else
:
log
.
error
(
"realtime_power_quality not exist"
)
except
Exception
as
e
:
log
.
exception
(
e
)
raise
DBException
total
+=
1
if
res
:
if
ctnum
!=
res
.
get
(
"ctnum"
):
log
.
info
(
f
"res = {res}"
)
log
.
error
(
f
"health_ctl_rate mysql ctnum={ctnum} payload ctnum={res.get('ctnum')} point_id={point_id} ctnum wrong!"
)
# 如果发现配置错误的点,以报文的配置为准
ctnum
=
res
.
get
(
"ctnum"
)
# 电压偏差
v_dev
=
res
.
get
(
"ua_dev"
)
if
ctnum
==
3
else
res
.
get
(
"uab_dev"
)
grade
=
get_dev_grade
(
dev_type
=
"v"
,
cur
=
v_dev
)
if
grade
and
grade
>=
60
:
stats
[
"v_dev"
]
+=
1
# 频率偏差
freq_dev
=
res
.
get
(
"freq_dev"
)
grade
=
get_dev_grade
(
dev_type
=
"freq"
,
cur
=
freq_dev
)
if
grade
and
grade
>=
60
:
stats
[
"freq_dev"
]
+=
1
# 三相电压不平衡度
ubl
=
res
.
get
(
"ubl"
)
grade
=
get_dev_grade
(
dev_type
=
"ubl"
,
cur
=
ubl
)
if
grade
and
grade
>=
60
:
stats
[
"ubl"
]
+=
1
# 功率因数
costtl
=
res
.
get
(
"costtl"
)
grade
=
get_dev_grade
(
dev_type
=
"costtl"
,
cur
=
costtl
)
if
grade
and
grade
>=
60
:
stats
[
"costtl"
]
+=
1
# (电压)谐波畸变率
thdu
=
res
.
get
(
"thdua"
)
if
ctnum
==
3
else
res
.
get
(
"thduab"
)
grade
=
get_dev_grade
(
dev_type
=
"thdu"
,
cur
=
thdu
)
if
grade
and
grade
>=
60
:
stats
[
"thdu"
]
+=
1
# 负载率
lf
=
res
.
get
(
"lf"
)
if
lf
is
None
:
stats
[
"lf"
]
+=
1
else
:
grade
=
get_dev_grade
(
dev_type
=
"lf"
,
cur
=
lf
)
if
grade
and
grade
>=
60
:
stats
[
"lf"
]
+=
1
else
:
# 没有数据指标可以知道这个是否合格的时候
stats
[
"v_dev"
]
+=
1
stats
[
"freq_dev"
]
+=
1
stats
[
"ubl"
]
+=
1
stats
[
"costtl"
]
+=
1
stats
[
"thdu"
]
+=
1
stats
[
"lf"
]
+=
1
total
=
1.0
*
total
time_str
=
time_format
.
get_datetime_str
(
real_tt
)
if
not
valid_mids
or
total
==
0
:
log
.
warn
(
f
"cid={cid} 无任何有效mid"
)
return
HealthCtlRateRes
(
real_time
=
time_str
,
lf
=
1
,
costtl
=
1
,
thdu
=
1
,
v_dev
=
1
,
freq_dev
=
1
,
ubl
=
1
,
)
return
HealthCtlRateRes
(
real_time
=
time_str
,
lf
=
stats
[
"lf"
]
/
total
,
costtl
=
stats
[
"costtl"
]
/
total
,
thdu
=
stats
[
"thdu"
]
/
total
,
v_dev
=
stats
[
"v_dev"
]
/
total
,
freq_dev
=
stats
[
"freq_dev"
]
/
total
,
ubl
=
stats
[
"ubl"
]
/
total
,
)
async
def
health_ctl_rate_service_new15
(
cid
):
if
cid
<=
0
:
if
cid
<=
0
:
log
.
error
(
"param error"
)
log
.
error
(
"param error"
)
raise
ParamException
(
message
=
"参数错误, cid参数必须是一个正整数!"
)
raise
ParamException
(
message
=
"参数错误, cid参数必须是一个正整数!"
)
...
@@ -210,10 +49,8 @@ async def health_ctl_rate_service_new15(cid):
...
@@ -210,10 +49,8 @@ async def health_ctl_rate_service_new15(cid):
if
not
is_succ
:
if
not
is_succ
:
log
.
warn
(
f
"cid={cid} 无任何有效mid"
)
log
.
warn
(
f
"cid={cid} 无任何有效mid"
)
return
HealthCtlRateRes
(
return
HealthCtlRateRes
(
real_time
=
time_str
,
lf
=
1
,
costtl
=
1
,
thdu
=
1
,
real_time
=
time_str
,
lf
=
1
,
costtl
=
1
,
thdu
=
1
,
v_dev
=
1
,
freq_dev
=
1
,
v_dev
=
1
,
freq_dev
=
1
,
ubl
=
1
)
ubl
=
1
,
)
if
not
results
[
"data"
]:
# 兼容:mt表(2.0架构)里面拿不到数据再从sid表(1.0架构)里面拿
if
not
results
[
"data"
]:
# 兼容:mt表(2.0架构)里面拿不到数据再从sid表(1.0架构)里面拿
td_s_tables
=
tuple
(
td_s_tables
=
tuple
(
...
@@ -225,11 +62,8 @@ async def health_ctl_rate_service_new15(cid):
...
@@ -225,11 +62,8 @@ async def health_ctl_rate_service_new15(cid):
is_succ
,
results
=
await
get_td_engine_data
(
url
,
sql
)
is_succ
,
results
=
await
get_td_engine_data
(
url
,
sql
)
if
not
is_succ
:
if
not
is_succ
:
log
.
warn
(
f
"cid={cid} 无任何有效mid"
)
log
.
warn
(
f
"cid={cid} 无任何有效mid"
)
return
HealthCtlRateRes
(
return
HealthCtlRateRes
(
real_time
=
time_str
,
lf
=
1
,
costtl
=
1
,
thdu
=
1
,
real_time
=
time_str
,
lf
=
1
,
costtl
=
1
,
thdu
=
1
,
v_dev
=
1
,
v_dev
=
1
,
freq_dev
=
1
,
ubl
=
1
)
freq_dev
=
1
,
ubl
=
1
,
)
head
=
parse_td_columns
(
results
)
head
=
parse_td_columns
(
results
)
datas
=
[]
datas
=
[]
...
@@ -275,10 +109,8 @@ async def health_ctl_rate_service_new15(cid):
...
@@ -275,10 +109,8 @@ async def health_ctl_rate_service_new15(cid):
if
grade
and
grade
>=
60
:
if
grade
and
grade
>=
60
:
stats
[
"lf"
]
+=
1
stats
[
"lf"
]
+=
1
if
total
==
0
:
if
total
==
0
:
return
HealthCtlRateRes
(
return
HealthCtlRateRes
(
real_time
=
time_str
,
lf
=
1
,
costtl
=
1
,
thdu
=
1
,
real_time
=
time_str
,
lf
=
1
,
costtl
=
1
,
thdu
=
1
,
v_dev
=
1
,
freq_dev
=
1
,
v_dev
=
1
,
freq_dev
=
1
,
ubl
=
1
)
ubl
=
1
,
)
return
HealthCtlRateRes
(
return
HealthCtlRateRes
(
real_time
=
time_str
,
real_time
=
time_str
,
lf
=
round_2
(
stats
[
"lf"
]
/
total
),
lf
=
round_2
(
stats
[
"lf"
]
/
total
),
...
...
unify_api/modules/home_page/views/count_info.py
View file @
4af81566
...
@@ -20,7 +20,7 @@ from unify_api.modules.home_page.components.count_info_proxy_cps import \
...
@@ -20,7 +20,7 @@ from unify_api.modules.home_page.components.count_info_proxy_cps import \
HsiResp
,
AiiResp
HsiResp
,
AiiResp
from
unify_api.modules.home_page.procedures.count_info_pds
import
(
from
unify_api.modules.home_page.procedures.count_info_pds
import
(
get_max_aiao_of_filed
,
normal_rate_of_location
,
get_max_aiao_of_filed
,
normal_rate_of_location
,
other_info
,
other_info_new15
,
other_info
,
power_count_info
,
power_count_info
,
electric_use_info
,
electric_use_info
,
power_charge_price
,
power_charge_price
,
...
@@ -62,7 +62,7 @@ async def post_count_info(request, body: CountInfoReq) -> CountInfoResp:
...
@@ -62,7 +62,7 @@ async def post_count_info(request, body: CountInfoReq) -> CountInfoResp:
# 今日报警数和累计安全运行天数
# 今日报警数和累计安全运行天数
# today_alarm_count, safe_run_days, alarm_count = await other_info(
# today_alarm_count, safe_run_days, alarm_count = await other_info(
# company_id)
# company_id)
today_alarm_count
,
safe_run_days
,
alarm_count
=
await
other_info
_new15
(
today_alarm_count
,
safe_run_days
,
alarm_count
=
await
other_info
(
company_id
)
company_id
)
# 实时负荷和近30日最高负荷
# 实时负荷和近30日最高负荷
...
...
unify_api/modules/home_page/views/health_index.py
View file @
4af81566
...
@@ -3,13 +3,13 @@
...
@@ -3,13 +3,13 @@
from
pot_libs.logger
import
log
from
pot_libs.logger
import
log
from
pot_libs.sanic_api
import
summary
,
description
from
pot_libs.sanic_api
import
summary
,
description
from
pot_libs.utils.exc_util
import
ParamException
,
DBException
,
BusinessException
from
pot_libs.utils.exc_util
import
ParamException
from
unify_api.modules.common.procedures
import
health_score
from
unify_api.modules.common.procedures
import
health_score
from
unify_api.modules.common.procedures.cids
import
get_
cids
,
get_
proxy_cids
from
unify_api.modules.common.procedures.cids
import
get_proxy_cids
from
unify_api.modules.common.procedures.health_score
import
load_manage_health_radar
from
unify_api.modules.common.procedures.health_score
import
\
load_manage_health_radar
from
unify_api.modules.home_page.service.health_index_service
import
\
from
unify_api.modules.home_page.service.health_index_service
import
\
health_ctl_rate_s
ervice
,
health_ctl_rate_service_new15
health_ctl_rate_s
rv
from
unify_api.modules.home_page.components.health_index
import
(
from
unify_api.modules.home_page.components.health_index
import
(
QueryDetails
,
QueryDetails
,
HealthIndexResp
,
HealthIndexResp
,
...
@@ -74,12 +74,13 @@ async def post_health_radar(req, body: QueryDetails) -> HealthRadarResp:
...
@@ -74,12 +74,13 @@ async def post_health_radar(req, body: QueryDetails) -> HealthRadarResp:
async
def
post_health_ctl_rate
(
req
,
body
:
QueryDetails
)
->
HealthCtlRateRes
:
async
def
post_health_ctl_rate
(
req
,
body
:
QueryDetails
)
->
HealthCtlRateRes
:
cid
=
body
.
cid
cid
=
body
.
cid
# return await health_ctl_rate_service(cid)
# return await health_ctl_rate_service(cid)
return
await
health_ctl_rate_s
ervice_new15
(
cid
)
return
await
health_ctl_rate_s
rv
(
cid
)
@
summary
(
"管理版用电健康首页健康统计"
)
@
summary
(
"管理版用电健康首页健康统计"
)
@
description
(
"安电U管理版本"
)
@
description
(
"安电U管理版本"
)
async
def
post_manage_health_index
(
req
,
body
:
ManageHealthIndexReq
)
->
ManageHealthIndexResp
:
async
def
post_manage_health_index
(
req
,
body
:
ManageHealthIndexReq
)
->
ManageHealthIndexResp
:
"""获取首页用电健康指数"""
"""获取首页用电健康指数"""
product
=
body
.
product
product
=
body
.
product
user_id
=
req
.
ctx
.
user_id
user_id
=
req
.
ctx
.
user_id
...
@@ -90,7 +91,8 @@ async def post_manage_health_index(req, body: ManageHealthIndexReq) -> ManageHea
...
@@ -90,7 +91,8 @@ async def post_manage_health_index(req, body: ManageHealthIndexReq) -> ManageHea
if
not
cids
:
if
not
cids
:
return
ManageHealthIndexResp
(
**
cid_map
)
return
ManageHealthIndexResp
(
**
cid_map
)
company_score_map
=
await
health_score
.
load_manage_health_radar
(
cids
)
company_score_map
=
await
health_score
.
load_manage_health_radar
(
cids
)
company_index_map
=
await
health_score
.
load_manage_health_index
(
company_score_map
)
company_index_map
=
await
health_score
.
load_manage_health_index
(
company_score_map
)
log
.
info
(
f
"company_index_map={company_index_map}"
)
log
.
info
(
f
"company_index_map={company_index_map}"
)
for
cid
,
health_index
in
company_index_map
.
items
():
for
cid
,
health_index
in
company_index_map
.
items
():
health_index
=
round
(
health_index
)
health_index
=
round
(
health_index
)
...
...
unify_api/modules/product_info/service/hardware_info.py
View file @
4af81566
...
@@ -3,7 +3,7 @@ from datetime import datetime
...
@@ -3,7 +3,7 @@ from datetime import datetime
from
unify_api.modules.common.dao.common_dao
import
monitor_by_cid
,
\
from
unify_api.modules.common.dao.common_dao
import
monitor_by_cid
,
\
company_by_cids
,
monitor_point_storey_join
,
company_by_cid
,
\
company_by_cids
,
monitor_point_storey_join
,
company_by_cid
,
\
detection_point_by_cid
,
monitor_page_by_cid
,
start_time_by_cids
,
\
detection_point_by_cid
,
monitor_page_by_cid
,
start_time_by_cids
,
\
tcs_runtime_by_cids
,
meter_by_mids
,
item_by_mitd_dao
tcs_runtime_by_cids
,
item_by_mitd_dao
from
unify_api.modules.common.procedures.points
import
point_to_mid
from
unify_api.modules.common.procedures.points
import
point_to_mid
from
unify_api.modules.product_info.components.hardware_cps
import
HisResp
,
\
from
unify_api.modules.product_info.components.hardware_cps
import
HisResp
,
\
HlsResp
,
HardwareInfoManResq
,
HardwareInfoListResq
HlsResp
,
HardwareInfoManResq
,
HardwareInfoListResq
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment