rank_service.py 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196
  1. #coding utf-8
  2. from db_helper import RedisHelper
  3. from config import set_config
  4. from utils import request_post
  5. import json
  6. from log import Log
  7. log_ = Log()
  8. config_ = set_config()
  9. def get_featurs(data, size, top_K, flow_pool_P, env_dict=None):
  10. recall_list = []
  11. vidKeys = []
  12. feature_dict = {}
  13. # defult value
  14. apptype = 0
  15. pagesource = "iLife-pages/user-videos-share-recommend"
  16. versioncode = "580"
  17. machineinfo_brand="HUAWEI"
  18. recommendsource = "0"
  19. machineinfo_platform = 'android'
  20. sencetype = '100078'
  21. mid = 'test1'
  22. machineinfo_model ='M2006C3LC'
  23. if env_dict:
  24. apptype = env_dict.get('app_type','')
  25. pagesource = env_dict.get('pagesource', '')
  26. versioncode = env_dict.get('versioncode', '')
  27. machineinfo_brand = env_dict.get('machineinfo_brand', '')
  28. machineinfo_model = env_dict.get('machineinfo_model', '')
  29. recommendsource = env_dict.get('recommendsource', '')
  30. machineinfo_platform = env_dict.get('machineinfo_platform', '')
  31. sencetype = env_dict.get('sencetype', '')
  32. redisObj = RedisHelper()
  33. pre_str = "v_ctr:"
  34. mid_list = []
  35. videoid_list = []
  36. apptype_list = []
  37. pagesource_list = []
  38. versioncode_list = []
  39. machineinfo_brand_list = []
  40. machineinfo_model_list = []
  41. recommendsource_list = []
  42. machineinfo_platform_list = []
  43. sencetype_list = []
  44. day_rov_list = []
  45. day_share_return_score_list = []
  46. day_share_score_list = []
  47. day_return_rate_list = []
  48. day_ctr_score_list = []
  49. day_play_pv_list = []
  50. day_play_users_list = []
  51. day_return_users_list = []
  52. day_share_pv_list = []
  53. day_view_pv_list = []
  54. day_view_users_list = []
  55. day_share_users = []
  56. for recall_item in data['rov_pool_recall']:
  57. if len(recall_item)<=0:
  58. continue
  59. vid = recall_item.get("videoId",0)
  60. mid_list.append(mid)
  61. videoid_list.append(vid)
  62. apptype_list.append(apptype)
  63. pagesource_list.append(pagesource)
  64. versioncode_list.append(versioncode)
  65. machineinfo_brand_list.append(machineinfo_brand)
  66. machineinfo_model_list.append(machineinfo_model)
  67. recommendsource_list.append(recommendsource)
  68. machineinfo_platform_list.append(machineinfo_platform)
  69. sencetype_list.append(sencetype)
  70. vidKeys.append(pre_str + str(vid))
  71. recall_list.append(recall_item)
  72. video_static_info = redisObj.get_batch_key(vidKeys)
  73. print("video_static_info:",video_static_info)
  74. if video_static_info:
  75. for i in range(len(video_static_info)):
  76. try:
  77. # print(video_scores[i])
  78. vid = vidKeys[i].replace(pre_str,"")
  79. if video_static_info[i] :
  80. per_video_staic = json.loads(video_static_info[i])
  81. day_rov_list.append(per_video_staic[0])
  82. day_share_return_score_list.append(per_video_staic[1])
  83. day_share_score_list.append(per_video_staic[2])
  84. day_return_rate_list.append(per_video_staic[3])
  85. day_ctr_score_list.append(per_video_staic[4])
  86. day_view_users_list.append(per_video_staic[5])
  87. day_view_pv_list.append(per_video_staic[6])
  88. day_play_users_list.append(per_video_staic[7])
  89. day_play_pv_list.append(per_video_staic[8])
  90. day_share_users.append(per_video_staic[9])
  91. day_share_pv_list.append(per_video_staic[10])
  92. day_return_users_list.append(per_video_staic[11])
  93. else:
  94. insert_static_default_fea(day_ctr_score_list, day_play_pv_list, day_play_users_list,
  95. day_return_rate_list, day_return_users_list, day_rov_list,
  96. day_share_pv_list, day_share_return_score_list, day_share_score_list,
  97. day_share_users, day_view_pv_list, day_view_users_list)
  98. except Exception:
  99. insert_static_default_fea(day_ctr_score_list, day_play_pv_list, day_play_users_list,
  100. day_return_rate_list, day_return_users_list, day_rov_list,
  101. day_share_pv_list, day_share_return_score_list, day_share_score_list,
  102. day_share_users, day_view_pv_list, day_view_users_list)
  103. else:
  104. for i in range(len(recall_list)):
  105. insert_static_default_fea(day_ctr_score_list, day_play_pv_list, day_play_users_list,
  106. day_return_rate_list, day_return_users_list, day_rov_list,
  107. day_share_pv_list, day_share_return_score_list, day_share_score_list,
  108. day_share_users, day_view_pv_list, day_view_users_list)
  109. feature_dict["mid_list"] = mid_list
  110. feature_dict["videoid_list"] = videoid_list
  111. feature_dict["apptype_list"] = apptype_list
  112. feature_dict["pagesource_list"] = pagesource_list
  113. feature_dict["versioncode_list"] = versioncode_list
  114. feature_dict["machineinfo_brand_list"] = machineinfo_brand_list
  115. feature_dict["machineinfo_model_list"] = machineinfo_model_list
  116. feature_dict["recommendsource_list"] = recommendsource_list
  117. feature_dict["machineinfo_model_list"] = machineinfo_model_list
  118. feature_dict["machineinfo_platform_list"] = machineinfo_platform_list
  119. feature_dict["sencetype_list"] = sencetype_list
  120. feature_dict["day_rov_list"] = day_rov_list
  121. feature_dict["day_share_return_score_list"] = day_share_return_score_list
  122. feature_dict["day_share_score_list"] = day_share_score_list
  123. feature_dict["day_return_rate_list"] = day_return_rate_list
  124. feature_dict["day_ctr_score_list"] = day_ctr_score_list
  125. feature_dict["day_ctr_score_list"] = day_ctr_score_list
  126. feature_dict["day_play_pv_list"] = day_play_pv_list
  127. feature_dict["day_play_users_list"] = day_play_users_list
  128. feature_dict["day_return_users_list"] = day_return_users_list
  129. feature_dict["day_share_pv_list"] = day_share_pv_list
  130. feature_dict["day_view_pv_list"] = day_view_pv_list
  131. feature_dict["day_view_users_list"] = day_view_users_list
  132. feature_dict["day_share_users_list"] = day_share_users
  133. return feature_dict, recall_list
  134. def insert_static_default_fea(day_ctr_score_list, day_play_pv_list, day_play_users_list, day_return_rate_list,
  135. day_return_users_list, day_rov_list, day_share_pv_list, day_share_return_score_list,
  136. day_share_score_list, day_share_users, day_view_pv_list, day_view_users_list):
  137. day_rov_list.append(0.0)
  138. day_share_return_score_list.append(0.0)
  139. day_share_score_list.append(0.0)
  140. day_return_rate_list.append(0.0)
  141. day_ctr_score_list.append(0.0)
  142. day_view_users_list.append(0)
  143. day_view_pv_list.append(0)
  144. day_play_users_list.append(0)
  145. day_play_pv_list.append(0)
  146. day_share_users.append(0)
  147. day_share_pv_list.append(0)
  148. day_return_users_list.append(0)
  149. def get_tf_serving_sores(feature_dict):
  150. #for k, v in feature_dict:
  151. inputs_data = {
  152. "mid": feature_dict["mid_list"],
  153. "videoid": feature_dict["videoid_list"],
  154. "apptype": feature_dict["apptype_list"],
  155. "pagesource": feature_dict["pagesource_list"],
  156. "versioncode": feature_dict["versioncode_list"],
  157. "machineinfo_brand": feature_dict["machineinfo_brand_list"],
  158. "machineinfo_model": feature_dict["machineinfo_model_list"],
  159. "recommendsource": feature_dict["recommendsource_list"],
  160. "machineinfo_platform": feature_dict["machineinfo_platform_list"],
  161. "sencetype": feature_dict["sencetype_list"],
  162. "day_rov": feature_dict["day_rov_list"],
  163. "day_share_return_score": feature_dict["day_share_return_score_list"],
  164. "day_share_score": feature_dict["day_share_score_list"],
  165. "day_return_rate": feature_dict["day_return_rate_list"],
  166. "day_ctr_score": feature_dict["day_ctr_score_list"],
  167. "day_play_pv": feature_dict["day_play_pv_list"],
  168. "day_play_users": feature_dict["day_play_users_list"],
  169. "day_share_pv": feature_dict["day_share_pv_list"],
  170. "day_return_users": feature_dict["day_return_users_list"],
  171. "day_share_users": feature_dict["day_share_users_list"],
  172. "day_view_pv": feature_dict["day_view_pv_list"],
  173. "day_view_users":feature_dict["day_view_users_list"]
  174. }
  175. request_data_dict= {}
  176. request_data_dict["inputs"] = inputs_data
  177. print(request_data_dict)
  178. request_data= json.dumps(request_data_dict)
  179. print(request_data)
  180. # 调用http接口
  181. result = request_post(request_url=config_.TF_SERVING_URL, request_data=request_data, timeout=(0.1, 1))
  182. # print("result:", result)
  183. if result is None:
  184. print("result is None")
  185. log_.info('call tf serving error,types: {}')
  186. return []
  187. print(result)
  188. return result