rank_service.py 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  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, rec_recall_vid_list, env_dict=None, video_static_info=None, video_hour_static_info=None):
  10. feature_dict = {}
  11. # defult value
  12. apptype = 4
  13. pagesource = ""
  14. versioncode = "580"
  15. machineinfo_brand="HUAWEI"
  16. recommendsource = "0"
  17. machineinfo_platform = 'android'
  18. sencetype = 100078
  19. machineinfo_model ='M2006C3LC'
  20. city_code = -1
  21. province_code = -1
  22. relevant_video_id = -1
  23. if env_dict and len(env_dict)>0:
  24. apptype = env_dict.get('app_type',4)
  25. pagesource = env_dict.get('pagesource', '')
  26. versioncode = env_dict.get('versioncode', 0)
  27. machineinfo_brand = env_dict.get('machineinfo_brand', '')
  28. machineinfo_model = env_dict.get('machineinfo_model', '')
  29. recommendsource = env_dict.get('recommendsource', '0')
  30. machineinfo_platform = env_dict.get('machineinfo_platform', '')
  31. sencetype = env_dict.get('sencetype', '')
  32. city_code = env_dict.get('city_code', -1)
  33. province_code = env_dict.get('province_code', -1)
  34. relevant_video_id = env_dict.get('relevant_video_id', -1)
  35. if city_code and city_code == "":
  36. city_code = -1
  37. if province_code and province_code == "":
  38. province_code = -1
  39. try:
  40. city_code = int(city_code)
  41. except:
  42. city_code = -1
  43. try:
  44. province_code = int(province_code)
  45. except:
  46. province_code = -1
  47. try:
  48. relevant_video_id = int(relevant_video_id)
  49. except:
  50. relevant_video_id = -1
  51. mid_list = []
  52. videoid_list = []
  53. apptype_list = []
  54. pagesource_list = []
  55. versioncode_list = []
  56. machineinfo_brand_list = []
  57. machineinfo_model_list = []
  58. machineinfo_platform_list = []
  59. sencetype_list = []
  60. day_rov_list = []
  61. day_share_return_score_list = []
  62. day_share_score_list = []
  63. day_return_rate_list = []
  64. day_ctr_score_list = []
  65. day_play_pv_list = []
  66. day_play_users_list = []
  67. day_return_users_list = []
  68. day_share_pv_list = []
  69. day_view_pv_list = []
  70. day_view_users_list = []
  71. day_share_users = []
  72. recommendsource_list = []
  73. relevant_video_list = []
  74. city_list = []
  75. province_list = []
  76. if rec_recall_vid_list and len(rec_recall_vid_list)>0:
  77. for i in range(len(rec_recall_vid_list)):
  78. mid_list.append(mid)
  79. videoid_list.append(rec_recall_vid_list[i])
  80. apptype_list.append(apptype)
  81. pagesource_list.append(pagesource)
  82. versioncode_list.append(versioncode)
  83. machineinfo_brand_list.append(machineinfo_brand)
  84. machineinfo_model_list.append(machineinfo_model)
  85. recommendsource_list.append(recommendsource)
  86. machineinfo_platform_list.append(machineinfo_platform)
  87. sencetype_list.append(sencetype)
  88. city_list.append(city_code)
  89. province_list.append(province_code)
  90. relevant_video_list.append(relevant_video_id)
  91. if video_static_info and len(video_static_info)>0:
  92. for i in range(len(video_static_info)):
  93. try:
  94. if video_static_info[i] and len(video_static_info[i])>0:
  95. per_video_staic = json.loads(video_static_info[i])
  96. day_rov_list.append(float(per_video_staic[0]))
  97. day_share_return_score_list.append(float(per_video_staic[1]))
  98. day_share_score_list.append(float(per_video_staic[2]))
  99. day_return_rate_list.append(float(per_video_staic[3]))
  100. day_ctr_score_list.append(float(per_video_staic[4]))
  101. day_view_users_list.append(int(per_video_staic[5]))
  102. day_view_pv_list.append(int(per_video_staic[6]))
  103. day_play_users_list.append(int(per_video_staic[7]))
  104. day_play_pv_list.append(int(per_video_staic[8]))
  105. day_share_users.append(int(per_video_staic[9]))
  106. day_share_pv_list.append(int(per_video_staic[10]))
  107. day_return_users_list.append(int(per_video_staic[11]))
  108. else:
  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. except Exception:
  114. insert_static_default_fea(day_ctr_score_list, day_play_pv_list, day_play_users_list,
  115. day_return_rate_list, day_return_users_list, day_rov_list,
  116. day_share_pv_list, day_share_return_score_list, day_share_score_list,
  117. day_share_users, day_view_pv_list, day_view_users_list)
  118. else:
  119. for i in range(len(rec_recall_vid_list)):
  120. insert_static_default_fea(day_ctr_score_list, day_play_pv_list, day_play_users_list,
  121. day_return_rate_list, day_return_users_list, day_rov_list,
  122. day_share_pv_list, day_share_return_score_list, day_share_score_list,
  123. day_share_users, day_view_pv_list, day_view_users_list)
  124. hour_rov_list = []
  125. hour_share_return_score_list =[]
  126. hour_share_score_list =[]
  127. hour_return_rate_list = []
  128. hour_ctr_score_list = []
  129. hour_play_pv_list = []
  130. hour_play_users_list = []
  131. hour_return_users_list = []
  132. hour_share_pv_list = []
  133. hour_view_pv_list = []
  134. hour_view_users_list = []
  135. hour_share_users = []
  136. if video_hour_static_info and len(video_hour_static_info)>0:
  137. for i in range(len(video_hour_static_info)):
  138. try:
  139. if video_hour_static_info[i] and len(video_hour_static_info[i])>0:
  140. per_hour_video_staic = json.loads(video_hour_static_info[i])
  141. hour_rov_list.append(float(per_hour_video_staic[0]))
  142. hour_share_return_score_list.append(float(per_hour_video_staic[1]))
  143. hour_share_score_list.append(float(per_hour_video_staic[2]))
  144. hour_return_rate_list.append(float(per_hour_video_staic[3]))
  145. hour_ctr_score_list.append(float(per_hour_video_staic[4]))
  146. hour_view_users_list.append(int(per_hour_video_staic[5]))
  147. hour_view_pv_list.append(int(per_hour_video_staic[6]))
  148. hour_play_users_list.append(int(per_hour_video_staic[7]))
  149. hour_play_pv_list.append(int(per_hour_video_staic[8]))
  150. hour_share_users.append(int(per_hour_video_staic[9]))
  151. hour_share_pv_list.append(int(per_hour_video_staic[10]))
  152. hour_return_users_list.append(int(per_hour_video_staic[11]))
  153. else:
  154. hour_rov_list.append(0.0)
  155. hour_share_return_score_list.append(0.0)
  156. hour_share_score_list.append(0.0)
  157. hour_return_rate_list.append(0.0)
  158. hour_ctr_score_list.append(0.0)
  159. hour_play_pv_list.append(0)
  160. hour_play_users_list.append(0)
  161. hour_return_users_list.append(0)
  162. hour_share_pv_list.append(0)
  163. hour_view_pv_list.append(0)
  164. hour_view_users_list.append(0)
  165. hour_share_users.append(0)
  166. except Exception:
  167. hour_rov_list.append(0.0)
  168. hour_share_return_score_list.append(0.0)
  169. hour_share_score_list.append(0.0)
  170. hour_return_rate_list.append(0.0)
  171. hour_ctr_score_list.append(0.0)
  172. hour_play_pv_list.append(0)
  173. hour_play_users_list.append(0)
  174. hour_return_users_list.append(0)
  175. hour_share_pv_list.append(0)
  176. hour_view_pv_list.append(0)
  177. hour_view_users_list.append(0)
  178. hour_share_users.append(0)
  179. else:
  180. for i in range(len(rec_recall_vid_list)):
  181. hour_rov_list.append(0.0)
  182. hour_share_return_score_list.append(0.0)
  183. hour_share_score_list.append(0.0)
  184. hour_return_rate_list.append(0.0)
  185. hour_ctr_score_list.append(0.0)
  186. feature_dict["mid_list"] = mid_list
  187. feature_dict["videoid_list"] = videoid_list
  188. feature_dict["apptype_list"] = apptype_list
  189. feature_dict["pagesource_list"] = pagesource_list
  190. feature_dict["versioncode_list"] = versioncode_list
  191. feature_dict["machineinfo_brand_list"] = machineinfo_brand_list
  192. feature_dict["machineinfo_model_list"] = machineinfo_model_list
  193. feature_dict["recommendsource_list"] = recommendsource_list
  194. feature_dict["machineinfo_model_list"] = machineinfo_model_list
  195. feature_dict["machineinfo_platform_list"] = machineinfo_platform_list
  196. feature_dict["sencetype_list"] = sencetype_list
  197. feature_dict["day_rov_list"] = day_rov_list
  198. feature_dict["day_share_return_score_list"] = day_share_return_score_list
  199. feature_dict["day_share_score_list"] = day_share_score_list
  200. feature_dict["day_return_rate_list"] = day_return_rate_list
  201. feature_dict["day_ctr_score_list"] = day_ctr_score_list
  202. feature_dict["day_play_pv_list"] = day_play_pv_list
  203. feature_dict["day_play_users_list"] = day_play_users_list
  204. feature_dict["day_return_users_list"] = day_return_users_list
  205. feature_dict["day_share_pv_list"] = day_share_pv_list
  206. feature_dict["day_view_pv_list"] = day_view_pv_list
  207. feature_dict["day_view_users_list"] = day_view_users_list
  208. feature_dict["day_share_users_list"] = day_share_users
  209. feature_dict["hour_rov_list"] = hour_rov_list
  210. feature_dict["hour_share_return_score_list"] = hour_share_return_score_list
  211. feature_dict["hour_share_score_list"] = hour_share_score_list
  212. feature_dict["hour_return_rate_list"] = hour_return_rate_list
  213. feature_dict["hour_ctr_score_list"] = hour_ctr_score_list
  214. feature_dict["hour_play_pv_list"] = hour_play_pv_list
  215. feature_dict["hour_play_users_list"] = hour_play_users_list
  216. feature_dict["hour_return_users_list"] = hour_return_users_list
  217. feature_dict["hour_share_pv_list"] = hour_share_pv_list
  218. feature_dict["hour_view_pv_list"] = hour_view_pv_list
  219. feature_dict["hour_view_users_list"] = hour_view_users_list
  220. feature_dict["hour_share_users_list"] = hour_share_users
  221. feature_dict["city_code"] = city_list
  222. feature_dict["province_code"] = province_list
  223. feature_dict["relevant_video_id"] = relevant_video_list
  224. return feature_dict
  225. def insert_static_default_fea(day_ctr_score_list, day_play_pv_list, day_play_users_list, day_return_rate_list,
  226. day_return_users_list, day_rov_list, day_share_pv_list, day_share_return_score_list,
  227. day_share_score_list, day_share_users, day_view_pv_list, day_view_users_list):
  228. day_rov_list.append(0.0)
  229. day_share_return_score_list.append(0.0)
  230. day_share_score_list.append(0.0)
  231. day_return_rate_list.append(0.0)
  232. day_ctr_score_list.append(0.0)
  233. day_view_users_list.append(0)
  234. day_view_pv_list.append(0)
  235. day_play_users_list.append(0)
  236. day_play_pv_list.append(0)
  237. day_share_users.append(0)
  238. day_share_pv_list.append(0)
  239. day_return_users_list.append(0)
  240. def get_tf_serving_sores(feature_dict):
  241. #for k, v in feature_dict:
  242. inputs_data = {
  243. "mid": feature_dict["mid_list"],
  244. "videoid": feature_dict["videoid_list"],
  245. "apptype": feature_dict["apptype_list"],
  246. "pagesource": feature_dict["pagesource_list"],
  247. "versioncode": feature_dict["versioncode_list"],
  248. "machineinfo_brand": feature_dict["machineinfo_brand_list"],
  249. "machineinfo_model": feature_dict["machineinfo_model_list"],
  250. "recommendsource": feature_dict["recommendsource_list"],
  251. "machineinfo_platform": feature_dict["machineinfo_platform_list"],
  252. "sencetype": feature_dict["sencetype_list"],
  253. "day_rov": feature_dict["day_rov_list"],
  254. "day_share_return_score": feature_dict["day_share_return_score_list"],
  255. "day_share_score": feature_dict["day_share_score_list"],
  256. "day_return_rate": feature_dict["day_return_rate_list"],
  257. "day_ctr_score": feature_dict["day_ctr_score_list"],
  258. "day_play_pv": feature_dict["day_play_pv_list"],
  259. "day_play_users": feature_dict["day_play_users_list"],
  260. "day_share_pv": feature_dict["day_share_pv_list"],
  261. "day_return_users": feature_dict["day_return_users_list"],
  262. "day_share_users": feature_dict["day_share_users_list"],
  263. "day_view_pv": feature_dict["day_view_pv_list"],
  264. "day_view_users":feature_dict["day_view_users_list"],
  265. "hour_rov": feature_dict["hour_rov_list"],
  266. "hour_share_score": feature_dict["hour_share_score_list"],
  267. "hour_share_return_score": feature_dict["hour_share_return_score_list"],
  268. "hour_return_rate": feature_dict["hour_return_rate_list"],
  269. "hour_ctr_score": feature_dict["hour_ctr_score_list"],
  270. "hour_play_pv": feature_dict["hour_play_pv_list"],
  271. "hour_play_users": feature_dict["hour_play_users_list"],
  272. "hour_share_pv": feature_dict["hour_share_pv_list"],
  273. "hour_return_users": feature_dict["hour_return_users_list"],
  274. "hour_share_users": feature_dict["hour_share_users_list"],
  275. "hour_view_pv": feature_dict["hour_view_pv_list"],
  276. "hour_view_users": feature_dict["hour_view_users_list"],
  277. "city_code": feature_dict['city_code'],
  278. "province_code": feature_dict['province_code'],
  279. "relevant_video_id":feature_dict['relevant_video_id']
  280. }
  281. request_data_dict= {}
  282. request_data_dict["inputs"] = inputs_data
  283. #print(request_data_dict)
  284. request_data= json.dumps(request_data_dict)
  285. #print(request_data)
  286. # 调用http接口
  287. result = request_post_data(config_.TF_SERVING_URL,request_data, timeout=(0.1, 1))
  288. #print("result:", result)
  289. if result is None:
  290. #print("result is None")
  291. log_.info('call tf serving error,types: {}')
  292. return []
  293. #print(result)
  294. return result