rank_service.py 11 KB

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