UserDataController.py 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. # -*- encoding: utf-8 -*-
  2. """
  3. @File : UserDataController.py
  4. @Time : 2022/8/16 10:44
  5. @Author : peng
  6. @Email : zhangdongming@asj6.wecom.work
  7. @Software: PyCharm
  8. """
  9. from django.db.models import Q, Count
  10. from django.views.generic.base import View
  11. import datetime
  12. from Ansjer.config import OSS_STS_ACCESS_SECRET, OSS_STS_ACCESS_KEY
  13. from Controller.DeviceConfirmRegion import Device_Region
  14. from Model.models import Device_User, CountryModel
  15. from Object.ResponseObject import ResponseObject
  16. from Object.TokenObject import TokenObject
  17. from Service.CommonService import CommonService
  18. # 用户数据
  19. class UserDataView(View):
  20. def get(self, request, *args, **kwargs):
  21. request.encoding = 'utf-8'
  22. operation = kwargs.get('operation')
  23. return self.validation(request.GET, request, operation)
  24. def post(self, request, *args, **kwargs):
  25. request.encoding = 'utf-8'
  26. operation = kwargs.get('operation')
  27. return self.validation(request.POST, request, operation)
  28. def validation(self, request_dict, request, operation):
  29. token_code, user_id, response = CommonService.verify_token_get_user_id(request_dict, request)
  30. if token_code != 0:
  31. return response.json(token_code)
  32. if operation == 'increase': # 查询用户新增数据
  33. return self.user_increase(request_dict, response)
  34. elif operation == 'active': # 查询用户活跃数据
  35. return self.user_active(request_dict, response)
  36. elif operation == 'region': # 查询用户地区分布
  37. return self.user_region(response)
  38. else:
  39. return response.json(414)
  40. @classmethod
  41. def user_increase(cls, request_dict, response):
  42. """
  43. 查询用户增长数据
  44. @param request_dict:请求参数
  45. @request_dict startTime:开始时间
  46. @request_dict endTime:结束时间
  47. @param response:响应对象
  48. @return:
  49. """
  50. start_time = request_dict.get('startTime', None)
  51. end_time = request_dict.get('endTime', None)
  52. time_unit = request_dict.get('timeUnit', None)
  53. if not all([start_time, end_time, time_unit]):
  54. return response.json(444, {'error param': 'startTime or endTime or timeUnit'})
  55. start_time = datetime.datetime.fromtimestamp(int(start_time))
  56. end_time = datetime.datetime.fromtimestamp(int(end_time))
  57. time_list = CommonService.cutting_time(start_time, end_time, time_unit)
  58. try:
  59. user_qs = Device_User.objects.filter(data_joined__range=(start_time, end_time))
  60. user_list = []
  61. count = user_qs.count()
  62. for item in time_list:
  63. user_date_qs = user_qs.filter(data_joined__range=item)
  64. s_time = CommonService.str_to_timestamp(item[0].strftime('%Y-%m-%d %H:%M:%S'))
  65. e_time = CommonService.str_to_timestamp(item[1].strftime('%Y-%m-%d %H:%M:%S'))
  66. user_dict = {
  67. 'count': user_date_qs.count(),
  68. 'startTime': s_time,
  69. 'endTime': e_time
  70. }
  71. user_list.append(user_dict)
  72. user_country_qs = user_qs.values('region_country').annotate(count=Count('region_country')).order_by(
  73. '-count')
  74. region_list = []
  75. for item in user_country_qs:
  76. country_id = item['region_country']
  77. country_qs = CountryModel.objects.filter(id=country_id).values('country_name')
  78. country_name = country_qs[0]['country_name'] if country_qs.exists() else '未知区域'
  79. rate = round(item['count'] / count * 100, 2)
  80. country_dict = {
  81. 'countryName': country_name,
  82. 'count': item['count'],
  83. 'rate': rate
  84. }
  85. region_list.append(country_dict)
  86. res = {
  87. 'user': user_list,
  88. 'region': region_list
  89. }
  90. return response.json(0, res)
  91. except Exception as e:
  92. return response.json(500, repr(e))
  93. @classmethod
  94. def user_active(cls, request_dict, response):
  95. """
  96. 查询用户活跃数据
  97. @param request_dict:请求参数
  98. @request_dict startTime:开始时间
  99. @request_dict endTime:结束时间
  100. @param response:响应对象
  101. @return:
  102. """
  103. start_time = request_dict.get('startTime', None)
  104. end_time = request_dict.get('endTime', None)
  105. time_unit = request_dict.get('timeUnit', None)
  106. if not all([start_time, end_time, time_unit]):
  107. return response.json(444, {'error param': 'startTime or endTime or timeUnit'})
  108. start_time = datetime.datetime.fromtimestamp(int(start_time))
  109. end_time = datetime.datetime.fromtimestamp(int(end_time))
  110. time_list = CommonService.cutting_time(start_time, end_time, time_unit)
  111. try:
  112. user_qs = Device_User.objects.filter(last_login__range=(start_time, end_time))
  113. user_list = []
  114. count = user_qs.count()
  115. for item in time_list:
  116. user_date_qs = user_qs.filter(last_login__range=item)
  117. s_time = CommonService.str_to_timestamp(item[0].strftime('%Y-%m-%d %H:%M:%S'))
  118. e_time = CommonService.str_to_timestamp(item[1].strftime('%Y-%m-%d %H:%M:%S'))
  119. user_dict = {
  120. 'count': user_date_qs.count(),
  121. 'startTime': s_time,
  122. 'endTime': e_time
  123. }
  124. user_list.append(user_dict)
  125. user_country_qs = user_qs.values('region_country').annotate(count=Count('region_country')).order_by(
  126. '-count')
  127. region_list = []
  128. for item in user_country_qs:
  129. country_id = item['region_country']
  130. country_qs = CountryModel.objects.filter(id=country_id).values('country_name')
  131. country_name = country_qs[0]['country_name'] if country_qs.exists() else '未知区域'
  132. rate = round(item['count'] / count * 100, 2)
  133. country_dict = {
  134. 'countryName': country_name,
  135. 'count': item['count'],
  136. 'rate': rate
  137. }
  138. region_list.append(country_dict)
  139. res = {
  140. 'user': user_list,
  141. 'region': region_list
  142. }
  143. return response.json(0, res)
  144. except Exception as e:
  145. return response.json(500, repr(e))
  146. @classmethod
  147. def user_region(cls, response):
  148. """
  149. 查询用户地区分布
  150. @param response:响应对象
  151. @return:
  152. """
  153. res = {
  154. 'countries': [],
  155. }
  156. try:
  157. user_qs = Device_User.objects.all()
  158. count = user_qs.count()
  159. user_qs = user_qs.values('region_country').annotate(count=Count('region_country')).order_by('-count')
  160. for item in user_qs:
  161. country_id = item['region_country']
  162. country_qs = CountryModel.objects.filter(id=country_id).values('country_name')
  163. item['country_name'] = country_qs[0]['country_name'] if country_qs.exists() else '未知区域'
  164. item['rate'] = round(item['count'] / count * 100, 2)
  165. res['countries'] = list(user_qs)
  166. return response.json(0, res)
  167. except Exception as e:
  168. return response.json(500, repr(e))