HomeDataController.py 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  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. import datetime
  10. import openpyxl
  11. import requests
  12. from django.db.models import Sum, Count
  13. from django.http import HttpResponse
  14. from django.utils.encoding import escape_uri_path
  15. from django.views.generic.base import View
  16. from Model.models import VideoPlaybackTimeModel, Device_User, Device_Info, Order_Model, CountryModel
  17. from Service.CommonService import CommonService
  18. # 业务数据
  19. class HomeDataView(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 == 'allData': # 查询首页数据
  33. return self.query_all_data(response)
  34. elif operation == 'salesVolume': # 查询销售额数据
  35. return self.query_sales_volume_data(request_dict, response)
  36. elif operation == 'global/allData': # 查询全球首页数据
  37. return self.query_global_all_data(request, request_dict, response)
  38. elif operation == 'global/salesVolume': # 查询全球销售额数据
  39. return self.query_global_sales_volume_data(request, request_dict, response)
  40. elif operation == 'exportData': # 查询全球销售额数据
  41. return self.export_data(request_dict, response)
  42. else:
  43. return response.json(414)
  44. @classmethod
  45. def query_all_data(cls, response):
  46. """
  47. 查询首页数据
  48. @param response:响应对象
  49. @return:
  50. """
  51. end_time = datetime.datetime.today().replace(hour=0, minute=0, second=0, microsecond=0)
  52. start_time = end_time + datetime.timedelta(days=-1)
  53. end_time_stamp = CommonService.str_to_timestamp(end_time.strftime('%Y-%m-%d %H:%M:%S'))
  54. start_time_stamp = CommonService.str_to_timestamp(start_time.strftime('%Y-%m-%d %H:%M:%S'))
  55. try:
  56. user_increase_qs = Device_User.objects.filter(data_joined__range=(start_time, end_time))
  57. user_increase_list = user_increase_qs.values('region_country').annotate(
  58. count=Count('region_country')).order_by('-count')
  59. for item in user_increase_list:
  60. country_qs = CountryModel.objects.filter(id=item['region_country']).values('country_name')
  61. item['countryName'] = country_qs[0]['country_name'] if country_qs.exists() else '未知区域'
  62. user_increase_count = user_increase_qs.count()
  63. user_active_count = Device_User.objects.filter(last_login__range=(start_time, end_time)).count()
  64. user_all_qs = Device_User.objects.filter(data_joined__lte=end_time)
  65. user_all_list = user_all_qs.values('region_country').annotate(
  66. count=Count('region_country')).order_by('-count')
  67. for item in user_all_list:
  68. country_qs = CountryModel.objects.filter(id=item['region_country']).values('country_name')
  69. item['countryName'] = country_qs[0]['country_name'] if country_qs.exists() else '未知区域'
  70. user_all_count = user_all_qs.count()
  71. device_increase_count = Device_Info.objects.filter(data_joined__range=(start_time, end_time)).values(
  72. 'UID').distinct().count()
  73. device_active_count = VideoPlaybackTimeModel.objects.filter(
  74. startTime__range=(start_time_stamp, end_time_stamp)).values('uid').distinct().count()
  75. device_all_count = Device_Info.objects.filter(data_joined__lte=end_time).values('UID').distinct().count()
  76. order_qs = Order_Model.objects.filter(status=1, addTime__range=(start_time_stamp, end_time_stamp))
  77. order_total = order_qs.aggregate(total=Sum('price'))['total']
  78. vod_order_total = order_qs.filter(order_type=0).aggregate(total=Sum('price'))['total']
  79. ai_order_total = order_qs.filter(order_type=1).aggregate(total=Sum('price'))['total']
  80. unicom_order_total = order_qs.filter(order_type=2).aggregate(total=Sum('price'))['total']
  81. order_all_qs = Order_Model.objects.filter(status=1, addTime__lte=end_time_stamp)
  82. order_all_total = order_all_qs.aggregate(total=Sum('price'))['total']
  83. vod_order_all_total = order_all_qs.filter(order_type=0).aggregate(total=Sum('price'))['total']
  84. ai_order_all_total = order_all_qs.filter(order_type=1).aggregate(total=Sum('price'))['total']
  85. unicom_order_all_total = order_all_qs.filter(order_type=2).aggregate(total=Sum('price'))['total']
  86. res = {
  87. 'userIncreaseCount': user_increase_count,
  88. 'userActiveCount': user_active_count,
  89. 'userAllCount': user_all_count,
  90. 'deviceIncreaseCount': device_increase_count,
  91. 'deviceActiveCount': device_active_count,
  92. 'deviceAllCount': device_all_count,
  93. 'orderTotal': round(order_total, 2) if order_total else 0,
  94. 'vodOrderTotal': round(vod_order_total, 2) if vod_order_total else 0,
  95. 'aiOrderTotal': round(ai_order_total, 2) if ai_order_total else 0,
  96. 'unicomOrderTotal': round(unicom_order_total, 2) if unicom_order_total else 0,
  97. 'orderAllTotal': round(order_all_total, 2) if order_all_total else 0,
  98. 'vodOrderAllTotal': round(vod_order_all_total, 2) if vod_order_all_total else 0,
  99. 'aiOrderAllTotal': round(ai_order_all_total, 2) if ai_order_all_total else 0,
  100. 'unicomOrderAllTotal': round(unicom_order_all_total, 2) if unicom_order_all_total else 0,
  101. 'userIncreaseRegion': list(user_increase_list),
  102. 'userAllRegion': list(user_all_list)
  103. }
  104. return response.json(0, res)
  105. except Exception as e:
  106. return response.json(500, repr(e))
  107. @classmethod
  108. def query_sales_volume_data(cls, request_dict, response):
  109. """
  110. 查询销售额数据
  111. @param request_dict:请求参数
  112. @request_dict startTime:开始时间
  113. @request_dict endTime:结束时间
  114. @request_dict timeUnit:时间单位
  115. @param response:响应对象
  116. @return:
  117. """
  118. start_time = request_dict.get('startTime', None)
  119. end_time = request_dict.get('endTime', None)
  120. time_unit = request_dict.get('timeUnit', None)
  121. if not all([start_time, end_time, time_unit]):
  122. return response.json(444, {'error param': 'startTime or endTime or timeUnit'})
  123. try:
  124. order_qs = Order_Model.objects.filter(addTime__range=(start_time, end_time))
  125. start_time = datetime.datetime.fromtimestamp(int(start_time))
  126. end_time = datetime.datetime.fromtimestamp(int(end_time))
  127. time_list = CommonService.cutting_time(start_time, end_time, time_unit)
  128. order_list = []
  129. for item in time_list:
  130. total = order_qs.filter(addTime__range=item).aggregate(total=Sum('price'))['total']
  131. res = {
  132. 'total': round(total, 2) if total else 0,
  133. 'startTime': item[0],
  134. 'endTime': item[1]
  135. }
  136. order_list.append(res)
  137. return response.json(0, order_list)
  138. except Exception as e:
  139. return response.json(500, repr(e))
  140. @classmethod
  141. def query_global_all_data(cls, request, request_dict, response):
  142. """
  143. 查询全球首页数据
  144. @param request:请求
  145. @param request_dict:请求参数
  146. @param response:响应对象
  147. @return:
  148. """
  149. url_list = CommonService.get_domain_name()
  150. try:
  151. headers = {
  152. 'Authorization': request.META.get('HTTP_AUTHORIZATION')
  153. }
  154. user_increase_count = 0
  155. user_active_count = 0
  156. user_all_count = 0
  157. device_increase_count = 0
  158. device_active_count = 0
  159. device_all_count = 0
  160. order_total = 0
  161. vod_order_total = 0
  162. ai_order_total = 0
  163. unicom_order_total = 0
  164. order_all_total = 0
  165. vod_order_all_total = 0
  166. ai_order_all_total = 0
  167. unicom_order_all_total = 0
  168. user_increase_temp_list = []
  169. user_increase_list = []
  170. user_increase_other_dict = {'count': 0, 'countryName': '其他', 'rate': ''}
  171. user_all_temp_list = []
  172. user_all_list = []
  173. user_all_other_dict = {'count': 0, 'countryName': '其他', 'rate': ''}
  174. for url in url_list:
  175. url = url + request.path.replace('global/', '')
  176. res = requests.get(url=url, params=request_dict, headers=headers)
  177. result = res.json()
  178. user_increase_count += result['result']['userIncreaseCount']
  179. user_active_count += result['result']['userActiveCount']
  180. user_all_count += result['result']['userAllCount']
  181. device_increase_count += result['result']['deviceIncreaseCount']
  182. device_active_count += result['result']['deviceActiveCount']
  183. device_all_count += result['result']['deviceAllCount']
  184. order_total += result['result']['orderTotal']
  185. vod_order_total += result['result']['vodOrderTotal']
  186. ai_order_total += result['result']['aiOrderTotal']
  187. unicom_order_total += result['result']['unicomOrderTotal']
  188. order_all_total += result['result']['orderAllTotal']
  189. vod_order_all_total += result['result']['vodOrderAllTotal']
  190. ai_order_all_total += result['result']['aiOrderAllTotal']
  191. unicom_order_all_total += result['result']['unicomOrderAllTotal']
  192. for item in result['result']['userIncreaseRegion']:
  193. flag = 0
  194. for each in user_increase_temp_list:
  195. if item['countryName'] == each['countryName']:
  196. each['count'] += item['count']
  197. flag = 1
  198. break
  199. if flag == 0:
  200. user_increase_temp_list.append(item)
  201. for item in result['result']['userAllRegion']:
  202. flag = 0
  203. for each in user_all_temp_list:
  204. if item['countryName'] == each['countryName']:
  205. each['count'] += item['count']
  206. flag = 1
  207. break
  208. if flag == 0:
  209. user_all_temp_list.append(item)
  210. if user_increase_temp_list:
  211. for item in user_increase_temp_list:
  212. rate = round(item['count'] / user_increase_count * 100, 2)
  213. if rate >= 10:
  214. item['rate'] = rate
  215. user_increase_list.append(item)
  216. else:
  217. user_increase_other_dict['count'] += item['count']
  218. user_increase_other_dict['rate'] = round(user_increase_other_dict['count'] / user_increase_count * 100, 2)
  219. user_increase_list.append(user_increase_other_dict)
  220. if user_all_temp_list:
  221. for item in user_all_temp_list:
  222. rate = round(item['count'] / user_all_count * 100, 2)
  223. if rate >= 10:
  224. item['rate'] = rate
  225. user_all_list.append(item)
  226. else:
  227. user_all_other_dict['count'] += item['count']
  228. user_all_other_dict['rate'] = round(user_all_other_dict['count'] / user_all_count * 100, 2)
  229. user_all_list.append(user_all_other_dict)
  230. res = {
  231. 'userIncreaseCount': user_increase_count,
  232. 'userActiveCount': user_active_count,
  233. 'userAllCount': user_all_count,
  234. 'deviceIncreaseCount': device_increase_count,
  235. 'deviceActiveCount': device_active_count,
  236. 'deviceAllCount': device_all_count,
  237. 'orderTotal': order_total,
  238. 'vodOrderTotal': vod_order_total,
  239. 'aiOrderTotal': ai_order_total,
  240. 'unicomOrderTotal': unicom_order_total,
  241. 'orderAllTotal': order_all_total,
  242. 'vodOrderAllTotal': vod_order_all_total,
  243. 'aiOrderAllTotal': ai_order_all_total,
  244. 'unicomOrderAllTotal': unicom_order_all_total,
  245. 'userIncreaseRegion': user_increase_list,
  246. 'userAllRegion': user_all_list
  247. }
  248. return response.json(0, res)
  249. except Exception as e:
  250. return response.json(500, repr(e))
  251. @classmethod
  252. def query_global_sales_volume_data(cls, request, request_dict, response):
  253. """
  254. 查询全球销售额数据
  255. @param request:请求
  256. @param request_dict:请求参数
  257. @param response:响应对象
  258. @return:
  259. """
  260. url_list = CommonService.get_domain_name()
  261. try:
  262. headers = {
  263. 'Authorization': request.META.get('HTTP_AUTHORIZATION')
  264. }
  265. order_list = []
  266. for url in url_list:
  267. url = url + request.path.replace('global/', '')
  268. res = requests.get(url=url, params=request_dict, headers=headers)
  269. result = res.json()
  270. for item in result['result']:
  271. flag = 0
  272. for each in order_list:
  273. if item['startTime'] == each['startTime'] and item['endTime'] == each['endTime']:
  274. each['total'] += item['total']
  275. break
  276. if flag == 0:
  277. order_list.append(item)
  278. return response.json(0, order_list)
  279. except Exception as e:
  280. return response.json(500, repr(e))
  281. @classmethod
  282. def export_data(cls, request_dict, response):
  283. """
  284. 下载文件
  285. @param request_dict:请求参数
  286. @request_dict tableData:表格数据
  287. @request_dict fileName:文件名
  288. @param response:响应对象
  289. @return:
  290. """
  291. table_data = request_dict.get('tableData', None)
  292. sheet_name = request_dict.get('fileName', None)
  293. if not all([table_data, sheet_name]):
  294. return response.json(444, {'error param': 'tableData or fileName'})
  295. table_data = eval(table_data)
  296. file_name = sheet_name + '.xlsx'
  297. try:
  298. res = HttpResponse(content_type='application/octet-stream')
  299. res['Content-Disposition'] = 'attachment; filename={}'.format(escape_uri_path(file_name))
  300. wb = openpyxl.Workbook()
  301. sh = wb.create_sheet(sheet_name, 0)
  302. for row, data in enumerate(table_data):
  303. if row == 0:
  304. sh.append(list(data.keys()))
  305. sh.append(list(data.values()))
  306. wb.save(res)
  307. # with open(file_path, 'rb') as f:
  308. # res = HttpResponse(f)
  309. # res['Content-Type'] = 'application/octet-stream'
  310. # res['Content-Disposition'] = 'attachment;filename="{}"'.format(file_name)
  311. return res
  312. except Exception as e:
  313. return response.json(500, repr(e))