StatisticsController.py 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. import json
  4. import time
  5. from django.db.models import Count
  6. from django.views.decorators.csrf import csrf_exempt
  7. from Model.models import UserAppFrequencyModel, AppFrequencyStatisticsModel, Device_User, \
  8. AppFrequencyYearStatisticsModel, EquipmentInfoExModel, EquipmentInfoExDayStatisticsModel
  9. from Object.ResponseObject import ResponseObject
  10. from Object.TokenObject import TokenObject
  11. @csrf_exempt
  12. def statistcsAppFrequency(request):
  13. request.encoding = 'utf-8'
  14. response = ResponseObject()
  15. if request.method == 'POST':
  16. request_dict = request.POST
  17. elif request.method == 'GET':
  18. request_dict = request.GET
  19. else:
  20. return response.json(444)
  21. token = TokenObject(request_dict.get('token', None))
  22. if token.code != 0:
  23. return response.json(token.code)
  24. target_year = request_dict.get('year', None)
  25. target_month = request_dict.get('month', None)
  26. localtime = time.localtime()
  27. current_month = localtime.tm_mon
  28. current_year = localtime.tm_year
  29. if target_year and target_month:
  30. current_year = int(target_year)
  31. current_month = int(target_month)
  32. time_struct = [current_year, 1, 1, 0, 0, 0, 0, 0, 0]
  33. # 该月的开始时间
  34. time_struct[1] = current_month
  35. start_time = time.mktime(tuple(time_struct))
  36. # 该月的结束时间
  37. time_struct[1] = current_month + 1
  38. end_time = time.mktime(tuple(time_struct))
  39. # 统计该月的数据
  40. uaf_qs = UserAppFrequencyModel.objects.filter(data_time__gte=start_time, data_time__lt=end_time) \
  41. .values('type').annotate(quantity=Count('id')).order_by()
  42. afs_qs = AppFrequencyStatisticsModel.objects.filter(year=current_year, month=current_month)
  43. if afs_qs.exists():
  44. afs_qs.update(data=json.dumps(uaf_qs))
  45. else:
  46. data = {
  47. 'data': json.dumps(list(uaf_qs)),
  48. 'month': current_month,
  49. 'year': current_year
  50. }
  51. AppFrequencyStatisticsModel.objects.create(**data)
  52. return response.json(0)
  53. @csrf_exempt
  54. def statistcsAppFrequencyYear(request):
  55. request.encoding = 'utf-8'
  56. response = ResponseObject()
  57. if request.method == 'POST':
  58. request_dict = request.POST
  59. elif request.method == 'GET':
  60. request_dict = request.GET
  61. else:
  62. return response.json(444)
  63. token = TokenObject(request_dict.get('token', None))
  64. if token.code != 0:
  65. return response.json(token.code)
  66. year = request_dict.get('year', None)
  67. localtime = time.localtime()
  68. current_year = localtime.tm_year
  69. if year:
  70. current_year = int(year)
  71. afs_qs = AppFrequencyStatisticsModel.objects.filter(year=current_year).values('data', 'month')
  72. # num = Device_User.objects.count()
  73. num = 300000
  74. res = []
  75. result = {
  76. 0: 0,
  77. 1: 0,
  78. 2: 0,
  79. 3: 0,
  80. 4: 0,
  81. 5: 0,
  82. 6: 0
  83. }
  84. quantity = 0
  85. for afs in afs_qs:
  86. data = json.loads(afs['data'])
  87. for item in data:
  88. result[item['type']] += item['quantity']
  89. quantity += item['quantity']
  90. tmps = []
  91. for k, v in result.items():
  92. tmp = {
  93. 'type': k,
  94. 'value': round(v / 12 / num, 3)
  95. }
  96. tmps.append(tmp)
  97. res.append({
  98. 'year': current_year,
  99. 'data': tmps
  100. })
  101. print(res)
  102. afys_qs = AppFrequencyYearStatisticsModel.objects.filter(year=current_year)
  103. #
  104. if afys_qs.exists():
  105. afys_qs.update(data=json.dumps(res))
  106. else:
  107. data = {
  108. 'data': json.dumps(res),
  109. 'year': current_year,
  110. 'num': num
  111. }
  112. AppFrequencyYearStatisticsModel.objects.create(**data)
  113. return response.json(0)
  114. @csrf_exempt
  115. def statistcsPushDay(request):
  116. request.encoding = 'utf-8'
  117. response = ResponseObject()
  118. if request.method == 'POST':
  119. request_dict = request.POST
  120. elif request.method == 'GET':
  121. request_dict = request.GET
  122. else:
  123. return response.json(444)
  124. # token = TokenObject(request_dict.get('token', None))
  125. # if token.code != 0:
  126. # return response.json(token.code)
  127. localtime = time.localtime()
  128. current_day = localtime.tm_mday+1
  129. print(current_day)
  130. time_struct = [localtime.tm_year, localtime.tm_mon, current_day - 1, 0, 0, 0, 0, 0, 0]
  131. start_time = int(time.mktime(tuple(time_struct)))
  132. print(start_time)
  133. time_struct[2] = current_day
  134. end_time = int(time.mktime(tuple(time_struct)))
  135. print(end_time)
  136. eq_qs = EquipmentInfoExModel.objects.filter(add_time__gte=start_time, add_time__lte=end_time)
  137. print(eq_qs.values())
  138. # 0:APNS推送,1:谷歌推送,2:极光推送
  139. now_time = int(time.time())
  140. jpush = EquipmentInfoExDayStatisticsModel(push_type=2, statistics_date=start_time, add_time=now_time, date_type=0)
  141. apns = EquipmentInfoExDayStatisticsModel(push_type=0, statistics_date=start_time, add_time=now_time, date_type=0)
  142. gcm = EquipmentInfoExDayStatisticsModel(push_type=1, statistics_date=start_time, add_time=now_time, date_type=0)
  143. total = EquipmentInfoExDayStatisticsModel(push_type=-1, statistics_date=start_time, add_time=now_time, date_type=0)
  144. for eq in eq_qs:
  145. if eq.push_type == 0:
  146. do_sum(eq, apns)
  147. elif eq.push_type == 1:
  148. do_sum(eq, gcm)
  149. elif eq.push_type == 2:
  150. do_sum(eq, jpush)
  151. do_sum(eq, total)
  152. datas = []
  153. datas.append(apns)
  154. datas.append(gcm)
  155. datas.append(jpush)
  156. datas.append(total)
  157. EquipmentInfoExDayStatisticsModel.objects.bulk_create(datas)
  158. return response.json(0)
  159. @csrf_exempt
  160. def statistcsPushMonth(request):
  161. request.encoding = 'utf-8'
  162. response = ResponseObject()
  163. if request.method == 'POST':
  164. request_dict = request.POST
  165. elif request.method == 'GET':
  166. request_dict = request.GET
  167. else:
  168. return response.json(444)
  169. # token = TokenObject(request_dict.get('token', None))
  170. # if token.code != 0:
  171. # return response.json(token.code)
  172. localtime = time.localtime()
  173. current_month = localtime.tm_mon
  174. time_struct = [localtime.tm_year, localtime.tm_mon, 1, 0, 0, 0, 0, 0, 0]
  175. start_time = int(time.mktime(tuple(time_struct)))
  176. time_struct[1] = current_month + 1
  177. end_time = int(time.mktime(tuple(time_struct)))
  178. eq_qs = EquipmentInfoExDayStatisticsModel.objects.filter(statistics_date__gte=start_time, statistics_date__lte=end_time, date_type=0)
  179. # 0:APNS推送,1:谷歌推送,2:极光推送
  180. now_time = int(time.time())
  181. jpush = EquipmentInfoExDayStatisticsModel(push_type=2, statistics_date=start_time, add_time=now_time, date_type=1)
  182. apns = EquipmentInfoExDayStatisticsModel(push_type=0, statistics_date=start_time, add_time=now_time, date_type=1)
  183. gcm = EquipmentInfoExDayStatisticsModel(push_type=1, statistics_date=start_time, add_time=now_time, date_type=1)
  184. total = EquipmentInfoExDayStatisticsModel(push_type=-1, statistics_date=start_time, add_time=now_time, date_type=1)
  185. for eq in eq_qs:
  186. if eq.push_type == 0:
  187. do_sum_two(eq, apns)
  188. elif eq.push_type == 1:
  189. do_sum_two(eq, gcm)
  190. elif eq.push_type == 2:
  191. do_sum_two(eq, jpush)
  192. do_sum_two(eq, total)
  193. datas = []
  194. datas.append(apns)
  195. datas.append(gcm)
  196. datas.append(jpush)
  197. datas.append(total)
  198. EquipmentInfoExDayStatisticsModel.objects.bulk_create(datas)
  199. return response.json(0)
  200. def do_sum(eq: EquipmentInfoExModel, target: EquipmentInfoExDayStatisticsModel):
  201. if eq.push_server_status == 200:
  202. target.number_of_successes += 1
  203. else:
  204. target.number_of_failures += 1
  205. if eq.push_device_status == 1:
  206. target.number_of_arrival += 1
  207. def do_sum_two(eq: EquipmentInfoExDayStatisticsModel, target: EquipmentInfoExDayStatisticsModel):
  208. target.number_of_successes += eq.number_of_successes
  209. target.number_of_failures += eq.number_of_failures
  210. target.number_of_arrival += eq.number_of_arrival