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
b3f0d6ca
Commit
b3f0d6ca
authored
Jun 21, 2023
by
ZZH
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
real time adio get from redis 2023-6-21
parent
9a60c699
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
86 additions
and
85 deletions
+86
-85
adio.py
unify_api/modules/adio/views/adio.py
+33
-31
elec_charge.py
unify_api/modules/elec_charge/views/elec_charge.py
+24
-25
hardware_pds.py
unify_api/modules/product_info/procedures/hardware_pds.py
+23
-28
time_format.py
unify_api/utils/time_format.py
+6
-1
No files found.
unify_api/modules/adio/views/adio.py
View file @
b3f0d6ca
...
...
@@ -4,11 +4,16 @@
# Date: 2020/7/9
import
json
import
time
import
pendulum
from
pot_libs.aredis_util.aredis_utils
import
RedisUtils
from
pot_libs.sanic_api
import
summary
,
description
,
examples
from
pot_libs.mysql_util.mysql_util
import
MysqlUtil
from
pot_libs.settings
import
SETTING
from
pot_libs.logger
import
log
from
unify_api.utils
import
time_format
from
unify_api.utils.time_format
import
CST
,
YMD_Hms
,
timestamp2dts
from
unify_api
import
constants
from
unify_api.utils.common_utils
import
round_2
from
unify_api.modules.adio.components.adio
import
(
...
...
@@ -134,39 +139,36 @@ async def post_adio_current(req, body: PageRequest) -> AdioCurrentResponse:
if
not
location_info
:
log
.
warning
(
"location_id error location_info empty"
)
return
AdioCurrentResponse
(
temperature
=
[],
residual_current
=
[])
# 获取mtid信息
mtid
=
list
(
location_info
.
values
())[
0
][
'mtid'
]
# 读取tdengine里面的数据
aido_data
=
await
get_adio_current_data
(
mtid
)
if
not
aido_data
:
# load real time adio
lids
=
list
(
location_info
.
keys
())
prefix
=
f
"real_time:adio:{SETTING.mysql_db}"
keys
=
[
f
"{prefix}:{lid}"
for
lid
in
lids
]
rt_rlts
=
await
RedisUtils
()
.
mget
(
keys
)
rt_adios
=
[
json
.
loads
(
r
)
for
r
in
rt_rlts
if
r
]
d_rt_adio
=
{
adio
[
"lid"
]:
adio
for
adio
in
rt_adios
}
if
not
d_rt_adio
:
return
AdioCurrentResponse
(
temperature
=
[],
residual_current
=
[])
temperature
=
[]
residual_current
=
[]
trans_field
=
{
"A相"
:
"temp1"
,
"B相"
:
"temp2"
,
"C相"
:
"temp3"
,
"N线"
:
"temp4"
}
for
location_id
,
item_info
in
location_info
.
items
():
time_str
=
aido_data
.
get
(
'ts'
)[:
19
]
item
=
item_info
.
get
(
"item"
,
""
)
if
item_info
.
get
(
"type"
)
==
"residual_current"
:
adio_current
=
AdioCurrent
(
type
=
"residual_current"
,
item
=
"漏电流"
,
real_time
=
time_str
,
value
=
aido_data
.
get
(
"residual_current"
)
)
residual_current
.
append
(
adio_current
)
else
:
type_filed
=
trans_field
.
get
(
item
)
adio_current
=
AdioCurrent
(
type
=
"temperature"
,
item
=
item
,
real_time
=
time_str
,
value
=
aido_data
.
get
(
type_filed
),
)
temperature
.
append
(
adio_current
)
return
AdioCurrentResponse
(
temperature
=
temperature
,
residual_current
=
residual_current
)
temp_lst
=
[]
rc_lst
=
[]
for
lid
,
loc_info
in
location_info
.
items
():
if
lid
not
in
d_rt_adio
:
ts
=
pendulum
.
now
(
tz
=
CST
)
.
int_timestamp
ad_value
=
""
else
:
ts
,
ad_value
=
d_rt_adio
[
lid
][
"ts"
],
d_rt_adio
[
lid
][
"v"
]
time_str
=
timestamp2dts
(
ts
,
YMD_Hms
)
if
loc_info
.
get
(
"type"
)
==
"residual_current"
:
adio_current
=
AdioCurrent
(
type
=
"residual_current"
,
item
=
"漏电流"
,
real_time
=
time_str
,
value
=
ad_value
)
rc_lst
.
append
(
adio_current
)
else
:
adio_current
=
AdioCurrent
(
type
=
"temperature"
,
item
=
loc_info
.
get
(
"item"
,
""
),
real_time
=
time_str
,
value
=
ad_value
,
)
temp_lst
.
append
(
adio_current
)
return
AdioCurrentResponse
(
temperature
=
temp_lst
,
residual_current
=
rc_lst
)
@
summary
(
"返回安全监测实时参数(老的)"
)
...
...
unify_api/modules/elec_charge/views/elec_charge.py
View file @
b3f0d6ca
...
...
@@ -174,24 +174,22 @@ async def post_aver_elec_price(req, body: AverPriceReq) -> AverPriceResp:
@
summary
(
'首页今日本月电量电费'
)
async
def
post_index_charge
(
req
,
body
:
IndexChargeReq
)
->
IndexChargeResp
:
cid
=
body
.
cid
p
oint_
id
=
body
.
point_id
today_start
,
today_end
,
month_start
,
month_end
=
today_month_date
()
pid
=
body
.
point_id
s_today
,
e_today
,
s_month
,
e_month
=
today_month_date
()
# 1. 今日电量电费spvf
kwh_t
,
charge_t
=
await
power_overview
(
today_start
,
today_end
,
point_id
,
cid
)
kwh_t
,
charge_t
=
await
power_overview
(
s_today
,
e_today
,
pid
,
cid
)
today_spvf
=
PowerViewRes
(
power
=
kwh_t
,
charge
=
charge_t
)
# 2. 本月电量电费spvf
kwh_m
,
charge_m
=
await
power_overview
(
month_start
,
month_end
,
point_id
,
cid
)
kwh_m
,
charge_m
=
await
power_overview
(
s_month
,
e_month
,
pid
,
cid
)
month_spvf
=
PowerViewRes
(
power
=
kwh_m
,
charge
=
charge_m
)
# 3. 今日平均电价和增长率
this_ck_t
,
last_ck_t
=
await
avg_ele_price
(
today_start
,
today_end
,
point_id
,
cid
,
this_ck_t
,
last_ck_t
=
await
avg_ele_price
(
s_today
,
e_today
,
pid
,
cid
,
date_type
=
"day"
)
today_power
=
AverPriceResp
(
this_power
=
this_ck_t
,
last_power
=
last_ck_t
)
# 4. 本月平均电价和增长率
this_ck_m
,
last_ck_m
=
await
avg_ele_price
(
month_start
,
month_end
,
point_id
,
cid
,
this_ck_m
,
last_ck_m
=
await
avg_ele_price
(
s_month
,
e_month
,
pid
,
cid
,
date_type
=
"month"
)
month_power
=
AverPriceResp
(
this_power
=
this_ck_m
,
last_power
=
last_ck_m
)
return
IndexChargeResp
(
today_spvf
=
today_spvf
,
month_spvf
=
month_spvf
,
...
...
@@ -278,12 +276,12 @@ async def post_month_today_proxy(req, body: ProductProxyReq) -> MtpResp:
log
.
info
(
f
"未查询到工厂userId:{user_id},product:{product}"
f
",proxy_id:{proxy_id}"
)
return
MtpResp
()
today_start
,
today_end
,
month_start
,
month_end
=
today_month_date
()
s_today
,
e_today
,
s_month
,
e_month
=
today_month_date
()
# 2. 本月/上月数据
last_month_start
,
last_month_end
=
last_time_str
(
month_start
,
month_end
,
last_month_start
,
last_month_end
=
last_time_str
(
s_month
,
e_month
,
"month"
,
True
)
this_month_p
,
this_month_charge
=
await
power_overview_proxy
(
month_start
,
month_end
,
cid_list
)
s_month
,
e_month
,
cid_list
)
last_month_p
,
last_month_charge
=
await
power_overview_proxy
(
last_month_start
,
last_month_end
,
cid_list
)
...
...
@@ -296,12 +294,12 @@ async def post_month_today_proxy(req, body: ProductProxyReq) -> MtpResp:
month_power_rate
=
(
this_month_total_power
-
last_month_total_power
)
/
last_month_total_power
# 2. 今日/昨日数据
last_day_start
,
last_day_end
=
last_time_str
(
today_start
,
today_end
,
"day"
)
this_day_p
,
this_day_charge
=
await
power_overview_proxy
(
today_start
,
today_end
,
last_day_start
,
last_day_end
=
last_time_str
(
s_today
,
e_today
,
"day"
)
this_day_p
,
this_day_charge
=
await
power_overview_proxy
(
s_today
,
e_today
,
cid_list
)
last_day_p
,
last_day_charge
=
await
power_overview_proxy
(
last_day_start
,
last_day_end
,
cid_list
)
last_day_p
,
last_day_charge
=
await
power_overview_proxy
(
last_day_start
,
last_day_end
,
cid_list
)
if
not
all
([
this_day_p
,
this_day_charge
,
last_day_p
,
last_day_charge
]):
return
MtpResp
()
...
...
@@ -343,8 +341,9 @@ async def post_power_sort_proxy(req, body: PopReq) -> PspResp:
end
=
now_date
# 2. 查询工厂电量电费信息
kwh_list
,
charge_list
,
price_list
=
await
power_aggs_cid_proxy
(
start
,
end
,
cid_list
,
date_type
)
kwh_list
,
charge_list
,
price_list
=
await
power_aggs_cid_proxy
(
start
,
end
,
cid_list
,
date_type
)
kwh_list_st
=
sorted
(
kwh_list
,
key
=
lambda
i
:
i
[
'value'
],
reverse
=
True
)
charge_list_st
=
sorted
(
charge_list
,
key
=
lambda
i
:
i
[
'value'
],
reverse
=
True
)
...
...
@@ -365,19 +364,19 @@ async def post_index_power_sort_proxy(req) -> IpspResp:
if
not
cid_list
:
log
.
info
(
f
"未查询到工厂, userId:{user_id} product:{product}"
)
return
IpspResp
()
today_start
,
today_end
,
month_start
,
month_end
=
today_month_date
()
s_today
,
e_today
,
s_month
,
e_month
=
today_month_date
()
# 2. 获取今日数据
kwh_list_d
,
charge_list_d
,
price_list_d
=
await
power_index_cid_proxy
(
today_start
,
today_end
,
cid_list
,
"day"
)
kwh_list_d_st
=
sorted
(
kwh_list_d
,
key
=
lambda
i
:
i
[
'value'
],
reverse
=
True
)[
:
5
]
s_today
,
e_today
,
cid_list
,
"day"
)
kwh_list_d_st
=
sorted
(
kwh_list_d
,
key
=
lambda
i
:
i
[
'value'
],
reverse
=
True
)[
:
5
]
charge_list_d_st
=
sorted
(
charge_list_d
,
key
=
lambda
i
:
i
[
'value'
],
reverse
=
True
)[:
5
]
price_list_d_st
=
sorted
(
price_list_d
,
key
=
lambda
i
:
i
[
'value'
],
reverse
=
True
)[:
5
]
# 2. 获取本月数据
kwh_list_m
,
charge_list_m
,
price_list_m
=
await
power_index_cid_proxy
(
month_start
,
month_end
,
cid_list
,
"month"
)
s_month
,
e_month
,
cid_list
,
"month"
)
kwh_list_m_st
=
sorted
(
kwh_list_m
,
key
=
lambda
i
:
i
[
'value'
],
reverse
=
True
)[:
5
]
charge_list_m_st
=
sorted
(
charge_list_m
,
key
=
lambda
i
:
i
[
'value'
],
...
...
unify_api/modules/product_info/procedures/hardware_pds.py
View file @
b3f0d6ca
...
...
@@ -24,7 +24,7 @@ def check_value_is_null(value):
return
value
in
(
None
,
"null"
,
"NULL"
,
""
)
async
def
get_user_hardware_info
(
c
ompany_
id
,
page_num
,
page_size
):
async
def
get_user_hardware_info
(
cid
,
page_num
,
page_size
):
# 1. 获取总的point数量
async
with
MysqlUtil
()
as
conn
:
point_sql_tmp
=
"select p.pid, p.name, p.create_time, p.update_time "
\
...
...
@@ -33,7 +33,7 @@ async def get_user_hardware_info(company_id, page_num, page_size):
"left join monitor_reuse m on m.mtid = c.mtid "
\
"where c.demolished=0 "
\
"and (p.cid =
%
s or m.cid =
%
s) "
points_tmp
=
await
conn
.
fetchall
(
sql
=
point_sql_tmp
,
args
=
(
company_id
,
company_
id
))
points_tmp
=
await
conn
.
fetchall
(
point_sql_tmp
,
(
cid
,
c
id
))
point_ids_tmp
=
[
point
[
"pid"
]
for
point
in
points_tmp
]
# 拆表
point_mid_map_tmp
,
point_count
=
await
point_to_mid
(
point_ids_tmp
)
...
...
@@ -44,7 +44,8 @@ async def get_user_hardware_info(company_id, page_num, page_size):
point_sql
=
"select pid, name, create_time, update_time, position "
\
"from point where cid =
%
s or pid in
%
s "
\
"limit
%
s offset
%
s"
points
=
await
conn
.
fetchall
(
sql
=
point_sql
,
args
=
(
company_id
,
tuple
(
point_id_tmp
),
page_size
,
offset
))
points
=
await
conn
.
fetchall
(
sql
=
point_sql
,
args
=
(
cid
,
tuple
(
point_id_tmp
),
page_size
,
offset
))
point_ids
=
[
point
[
"pid"
]
for
point
in
points
]
# 获取所有poin_id和mid对应关系
point_mid_map
,
point_count_limit
=
await
point_to_mid
(
point_ids
)
...
...
@@ -57,7 +58,8 @@ async def get_user_hardware_info(company_id, page_num, page_size):
meter_changes
=
[]
if
point_ids
:
async
with
MysqlUtil
()
as
conn
:
meter_changes
=
await
conn
.
fetchall
(
meter_change_sql
,
args
=
(
tuple
(
point_ids
),))
meter_changes
=
await
conn
.
fetchall
(
meter_change_sql
,
args
=
(
tuple
(
point_ids
),))
point_meter_map
=
defaultdict
(
dict
)
for
i
in
meter_changes
:
point_meter_map
[
i
[
"pid"
]]
=
i
...
...
@@ -70,7 +72,7 @@ async def get_user_hardware_info(company_id, page_num, page_size):
meters
=
await
conn
.
fetchall
(
meter_sql
,
args
=
(
tuple
(
meter_ids
),))
async
with
MysqlUtil
()
as
conn
:
meter_param_record_sql
=
"""SELECT
meter_param_record_sql
=
"""SELECT
mtid,
ptr,
ctr,
...
...
@@ -105,7 +107,8 @@ async def get_user_hardware_info(company_id, page_num, page_size):
# 组装pid和meter的对应关系
for
point_id
,
meter_change
in
point_meter_map
.
items
():
point_meter_map
[
point_id
]
=
meter_map
[
meter_change
[
"mtid"
]]
if
meter_change
[
"mtid"
]
else
{}
point_meter_map
[
point_id
]
=
meter_map
[
meter_change
[
"mtid"
]]
if
\
meter_change
[
"mtid"
]
else
{}
datas
=
[]
for
point
in
points
:
...
...
@@ -147,7 +150,8 @@ async def get_user_hardware_info(company_id, page_num, page_size):
data
[
"ct_change"
]
=
meter_param
[
"ctr"
]
data
[
"wiring_type"
]
=
"两表法"
if
meter_param
[
"ctnum"
]
==
2
else
"三表法"
if
not
check_value_is_null
(
meter_param
[
"voltage_side"
]):
data
[
"high_or_low_side"
]
=
"高压侧"
if
meter_param
[
"voltage_side"
]
==
1
else
"低压侧"
data
[
"high_or_low_side"
]
=
"高压侧"
if
meter_param
[
"voltage_side"
]
==
1
else
"低压侧"
if
not
check_value_is_null
(
meter_param
[
"tc"
]):
data
[
"inline_capacity"
]
=
meter_param
[
"tc"
]
if
not
check_value_is_null
(
meter_param
[
"vc"
]):
...
...
@@ -165,7 +169,7 @@ async def get_user_hardware_info_new15(company_id, page_num, page_size):
"on p.mtid=m.mtid where m.demolished=0 and p.cid=
%
s "
\
"ORDER BY p.create_time desc"
async
with
MysqlUtil
()
as
conn
:
datas
=
await
conn
.
fetchall
(
sql
=
sql
,
args
=
(
company_id
,
))
datas
=
await
conn
.
fetchall
(
sql
=
sql
,
args
=
(
company_id
,))
results
=
[]
if
page_num
>
0
and
page_size
>
0
:
start
=
(
page_num
-
1
)
*
page_size
...
...
@@ -175,8 +179,8 @@ async def get_user_hardware_info_new15(company_id, page_num, page_size):
for
data
in
datas
:
high_or_low_side
=
"高压侧"
if
data
[
"voltage_side"
]
==
1
else
"低压侧"
start_time
=
datetime
.
strftime
(
datetime
.
fromtimestamp
(
data
[
"create_time"
]),
"
%
Y-
%
m-
%
d
%
H:
%
M"
)
datetime
.
fromtimestamp
(
data
[
"create_time"
]),
"
%
Y-
%
m-
%
d
%
H:
%
M"
)
update_time
=
datetime
.
strftime
(
datetime
.
fromtimestamp
(
data
[
"update_time"
]),
"
%
Y-
%
m-
%
d
%
H:
%
M"
)
...
...
@@ -208,28 +212,20 @@ async def hardware_statistics(company_id):
:param company_id:
:return:
"""
# async with MysqlUtil() as conn:
# point_sql = "select count(*) as point_count from point where cid = %s"
# point_count_map = await conn.fetchone(sql=point_sql, args=(company_id,))
#
# point_count = point_count_map["point_count"]
async
with
MysqlUtil
()
as
conn
:
point_sql
=
"select p.pid from point p "
\
"left JOIN monitor c on p.mtid = c.mtid "
\
"left join monitor_reuse m on c.mtid = m.mtid "
\
"where c.demolished=0 and "
\
"(p.cid =
%
s or m.cid=
%
s)"
points
=
await
conn
.
fetchall
(
sql
=
point_sql
,
args
=
(
company_id
,
company_id
))
sql
=
"select p.pid from point p "
\
"left JOIN monitor c on p.mtid = c.mtid "
\
"left join monitor_reuse m on c.mtid = m.mtid "
\
"where c.demolished=0 and "
\
"(p.cid =
%
s or m.cid=
%
s)"
points
=
await
conn
.
fetchall
(
sql
,
(
company_id
,
company_id
))
point_ids
=
[
point
[
"pid"
]
for
point
in
points
]
mid_info
,
point_count
=
await
point_to_mid
(
point_ids
)
async
with
MysqlUtil
()
as
conn
:
inline_sql
=
"select count(*) as inline_count from inline where "
\
"cid =
%
s"
inline_count_map
=
await
conn
.
fetchone
(
sql
=
inline_sql
,
args
=
(
company_id
,))
inline_count_map
=
await
conn
.
fetchone
(
inline_sql
,
(
company_id
,))
inline_count
=
inline_count_map
[
"inline_count"
]
async
with
MysqlUtil
()
as
conn
:
...
...
@@ -242,8 +238,7 @@ async def hardware_statistics(company_id):
# power_capacity供电容量字段计算错误,改为inline表的tc_runtime字段相加
async
with
MysqlUtil
()
as
conn
:
capacity_sql
=
"select tc_runtime from inline where cid =
%
s"
capacity_list
=
await
conn
.
fetchall
(
sql
=
capacity_sql
,
args
=
(
company_id
,))
capacity_list
=
await
conn
.
fetchall
(
capacity_sql
,
(
company_id
,))
power_capacity
=
0
for
capacity
in
capacity_list
:
if
capacity
and
capacity
.
get
(
"tc_runtime"
):
...
...
@@ -253,4 +248,4 @@ async def hardware_statistics(company_id):
"legal_measurement_number"
:
inline_count
,
"start_time"
:
start_time
,
"power_capacity"
:
power_capacity
if
power_capacity
else
""
,
}
\ No newline at end of file
}
unify_api/utils/time_format.py
View file @
b3f0d6ca
...
...
@@ -294,7 +294,7 @@ def last_15min_range():
def
today_month_date
():
"""今日本月和上一周期时间 今天10:00/昨日10:00"""
# today_start, today_end, month_start, month_end
now
=
pendulum
.
now
()
now
=
pendulum
.
now
(
tz
=
CST
)
# 今天开始到结束时间
today_end
=
str
(
now
.
format
(
YMD_Hms
))
today_start
=
str
(
now
.
start_of
(
'day'
)
.
format
(
YMD_Hms
))
...
...
@@ -1491,3 +1491,8 @@ def get_time_diff(start, end):
def
get_15min_ago
(
time_fmt
=
"YYYY-MM-DD HH:mm:ss"
):
return
my_pendulum
.
now
(
tz
=
CST
)
.
subtract
(
minutes
=
15
)
.
format
(
time_fmt
)
def
timestamp2dts
(
timestamp
,
dt_fmt
):
dt
=
pendulum
.
from_timestamp
(
timestamp
,
tz
=
CST
)
return
dt
.
format
(
dt_fmt
)
\ No newline at end of file
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