MibooGram/modules/action_log/client.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

152 lines
5.7 KiB
Python
Raw Permalink Normal View History

2024-07-06 05:35:04 +00:00
from typing import List, Dict, Union
2024-07-06 10:20:34 +00:00
from simnet.models.zzz.self_help import ZZZSelfHelpActionLog, ZZZSelfHelpActionLogReason
2024-07-06 05:35:04 +00:00
from modules.action_log.date import DateUtils
from modules.action_log.models import ActionLogPair
class ActionLogAnalyse(DateUtils):
def __init__(self, data: List[ZZZSelfHelpActionLog], data2: Dict[int, int]):
super().__init__()
self.data = data
self.data2 = data2
self.pairs = self.init_pair(data)
self.this_week_data: List[ActionLogPair] = []
self.last_week_data: List[ActionLogPair] = []
self.this_month_data: List[ActionLogPair] = []
self.last_month_data: List[ActionLogPair] = []
self.init_pair_data()
def init_pair_data(self):
"""通过时间点判断数据属于哪个时间段"""
for d in self.pairs:
if self.week_start <= d.start_time < self.week_end:
self.this_week_data.append(d)
elif self.week_last_start <= d.start_time < self.week_last_end:
self.last_week_data.append(d)
if self.month_start <= d.start_time < self.month_end:
self.this_month_data.append(d)
elif self.month_last_start <= d.start_time < self.month_last_end:
self.last_month_data.append(d)
@staticmethod
def init_pair(data: List[ZZZSelfHelpActionLog]) -> List[ActionLogPair]:
pairs = []
2024-07-06 10:20:34 +00:00
start = None
for d in data:
if start:
if d.reason == ZZZSelfHelpActionLogReason.LOG_OUT:
pairs.append(ActionLogPair(start=start, end=d))
start = None
elif d.reason == ZZZSelfHelpActionLogReason.LOG_IN:
start = d
2024-07-06 05:35:04 +00:00
return pairs
def get_this_week_duration(self) -> int:
"""本周时长"""
return (sum(d.duration.seconds for d in self.this_week_data)) if self.this_week_data else 0
def get_last_week_duration(self) -> int:
"""上周时长"""
return (sum(d.duration.seconds for d in self.last_week_data)) if self.last_week_data else 0
def get_this_month_duration(self) -> int:
"""本月时长"""
return (sum(d.duration.seconds for d in self.this_month_data)) if self.this_month_data else 0
def get_last_month_duration(self) -> int:
"""上月时长"""
return (sum(d.duration.seconds for d in self.last_month_data)) if self.last_month_data else 0
def get_this_month_avg_duration(self) -> float:
"""本月平均时长"""
data_len = len(self.this_month_data)
return (self.get_this_month_duration() / data_len) if data_len else 0
def get_last_month_avg_duration(self) -> float:
"""上月平均时长"""
data_len = len(self.last_month_data)
return (self.get_last_month_duration() / data_len) if data_len else 0
def get_this_week_long_duration(self) -> int:
"""周最长会话"""
return (max(d.duration.seconds for d in self.this_week_data)) if self.this_week_data else 0
def get_this_week_short_duration(self) -> int:
"""周最短会话"""
return (min(d.duration.seconds for d in self.this_week_data)) if self.this_week_data else 0
def get_this_month_long_duration(self) -> int:
"""月最长会话"""
return (max(d.duration.seconds for d in self.this_month_data)) if self.this_month_data else 0
def get_this_month_short_duration(self) -> int:
"""月最短会话"""
return (min(d.duration.seconds for d in self.this_month_data)) if self.this_month_data else 0
@staticmethod
def format_sec(sec: Union[int, float]) -> str:
hour = sec // 3600
minute = (sec % 3600) // 60
second = sec % 60
if hour:
return f"{int(hour)}{int(minute)}"
if minute:
return f"{int(minute)}{int(second)}"
return f"{int(second)}"
def get_data(self) -> List[Dict[str, str]]:
data = {
"本周时长": self.get_this_week_duration(),
"上周时长": self.get_last_week_duration(),
"本月时长": self.get_this_month_duration(),
"上月时长": self.get_last_month_duration(),
"本月平均": self.get_this_month_avg_duration(),
"上月平均": self.get_last_month_avg_duration(),
"周最长会话": self.get_this_week_long_duration(),
"月最长会话": self.get_this_month_long_duration(),
"周最短会话": self.get_this_week_short_duration(),
"月最短会话": self.get_this_month_short_duration(),
}
datas = []
for k, v in data.items():
datas.append(
{
"name": k,
"value": self.format_sec(v),
}
)
max_hour = max(self.data2, key=self.data2.get)
min_hour = min(self.data2, key=self.data2.get)
datas.append({"name": "最常上线", "value": f"{max_hour}"})
datas.append({"name": "最少上线", "value": f"{min_hour}"})
return datas
def get_line_data(self) -> List[Dict[str, str]]:
data = []
for k, v in self.data2.items():
data.append(
{
"month": f"{k}",
"value": v,
}
)
return data
def get_record_data(self) -> List[Dict[str, str]]:
data = []
limit = 4
data_len = len(self.data) - 1
for i in range(data_len, data_len - limit, -1):
record = self.data[i]
data.append(
{
"time": record.time.strftime("%Y年%m月%d%H:%M:%S"),
"reason": record.reason.value,
}
)
return data