rank_service.py 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254
  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. 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. 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. city_code = env_dict.get('city_code', -1)
  32. province_code = env_dict.get('province_code', -1)
  33. if city_code and city_code == "":
  34. city_code = -1
  35. if province_code and province_code == "":
  36. province_code = -1
  37. try:
  38. city_code = int(city_code)
  39. except:
  40. city_code = -1
  41. try:
  42. province_code = int(province_code)
  43. except:
  44. province_code = -1
  45. mid_list = []
  46. videoid_list = []
  47. apptype_list = []
  48. pagesource_list = []
  49. versioncode_list = []
  50. machineinfo_brand_list = []
  51. machineinfo_model_list = []
  52. machineinfo_platform_list = []
  53. sencetype_list = []
  54. day_rov_list = []
  55. day_share_return_score_list = []
  56. day_share_score_list = []
  57. day_return_rate_list = []
  58. day_ctr_score_list = []
  59. day_play_pv_list = []
  60. day_play_users_list = []
  61. day_return_users_list = []
  62. day_share_pv_list = []
  63. day_view_pv_list = []
  64. day_view_users_list = []
  65. day_share_users = []
  66. recommendsource_list = []
  67. recall_list = env_dict.get('recall_list', [])
  68. city_list = []
  69. province_list = []
  70. if recall_list and len(recall_list)>0:
  71. for i in range(len(recall_list)):
  72. mid_list.append(mid)
  73. videoid_list.append(int(recall_list[i]))
  74. apptype_list.append(apptype)
  75. pagesource_list.append(pagesource)
  76. versioncode_list.append(versioncode)
  77. machineinfo_brand_list.append(machineinfo_brand)
  78. machineinfo_model_list.append(machineinfo_model)
  79. recommendsource_list.append(recommendsource)
  80. machineinfo_platform_list.append(machineinfo_platform)
  81. sencetype_list.append(sencetype)
  82. city_list.append(city_code)
  83. province_list.append(province_code)
  84. video_static_info = env_dict.get('vid_day_fea_list', [])
  85. video_hour_static_info = env_dict.get('vid_hour_fea_list', [])
  86. #print("video_static_info:",video_static_info)
  87. if video_static_info and len(video_static_info)>0:
  88. for i in range(len(video_static_info)):
  89. try:
  90. if video_static_info[i] and len(video_static_info[i])>0:
  91. per_video_staic = json.loads(video_static_info[i])
  92. day_rov_list.append(float(per_video_staic[0]))
  93. day_share_return_score_list.append(float(per_video_staic[1]))
  94. day_share_score_list.append(float(per_video_staic[2]))
  95. day_return_rate_list.append(float(per_video_staic[3]))
  96. day_ctr_score_list.append(float(per_video_staic[4]))
  97. # day_view_users_list.append(int(per_video_staic[5]))
  98. # day_view_pv_list.append(int(per_video_staic[6]))
  99. # day_play_users_list.append(int(per_video_staic[7]))
  100. # day_play_pv_list.append(int(per_video_staic[8]))
  101. # day_share_users.append(int(per_video_staic[9]))
  102. # day_share_pv_list.append(int(per_video_staic[10]))
  103. # day_return_users_list.append(int(per_video_staic[11]))
  104. else:
  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. except Exception:
  110. insert_static_default_fea(day_ctr_score_list, day_play_pv_list, day_play_users_list,
  111. day_return_rate_list, day_return_users_list, day_rov_list,
  112. day_share_pv_list, day_share_return_score_list, day_share_score_list,
  113. day_share_users, day_view_pv_list, day_view_users_list)
  114. else:
  115. for i in range(len(recall_list)):
  116. insert_static_default_fea(day_ctr_score_list, day_play_pv_list, day_play_users_list,
  117. day_return_rate_list, day_return_users_list, day_rov_list,
  118. day_share_pv_list, day_share_return_score_list, day_share_score_list,
  119. day_share_users, day_view_pv_list, day_view_users_list)
  120. hour_rov_list = []
  121. hour_share_return_score_list =[]
  122. hour_share_score_list =[]
  123. hour_return_rate_list = []
  124. hour_ctr_score_list = []
  125. if video_hour_static_info and len(video_hour_static_info)>0:
  126. for i in range(len(video_hour_static_info)):
  127. try:
  128. if video_hour_static_info[i] and len(video_hour_static_info[i])>0:
  129. per_hour_video_staic = json.loads(video_hour_static_info[i])
  130. hour_rov_list.append(float(per_hour_video_staic[0]))
  131. hour_share_return_score_list.append(float(per_hour_video_staic[1]))
  132. hour_share_score_list.append(float(per_hour_video_staic[2]))
  133. hour_return_rate_list.append(float(per_hour_video_staic[3]))
  134. hour_ctr_score_list.append(float(per_hour_video_staic[4]))
  135. else:
  136. hour_rov_list.append(0.0)
  137. hour_share_return_score_list.append(0.0)
  138. hour_share_score_list.append(0.0)
  139. hour_return_rate_list.append(0.0)
  140. hour_ctr_score_list.append(0.0)
  141. except Exception:
  142. hour_rov_list.append(0.0)
  143. hour_share_return_score_list.append(0.0)
  144. hour_share_score_list.append(0.0)
  145. hour_return_rate_list.append(0.0)
  146. hour_ctr_score_list.append(0.0)
  147. else:
  148. for i in range(len(recall_list)):
  149. hour_rov_list.append(0.0)
  150. hour_share_return_score_list.append(0.0)
  151. hour_share_score_list.append(0.0)
  152. hour_return_rate_list.append(0.0)
  153. hour_ctr_score_list.append(0.0)
  154. feature_dict["mid_list"] = mid_list
  155. feature_dict["videoid_list"] = videoid_list
  156. feature_dict["apptype_list"] = apptype_list
  157. feature_dict["pagesource_list"] = pagesource_list
  158. feature_dict["versioncode_list"] = versioncode_list
  159. feature_dict["machineinfo_brand_list"] = machineinfo_brand_list
  160. feature_dict["machineinfo_model_list"] = machineinfo_model_list
  161. feature_dict["recommendsource_list"] = recommendsource_list
  162. feature_dict["machineinfo_model_list"] = machineinfo_model_list
  163. feature_dict["machineinfo_platform_list"] = machineinfo_platform_list
  164. feature_dict["sencetype_list"] = sencetype_list
  165. feature_dict["day_rov_list"] = day_rov_list
  166. feature_dict["day_share_return_score_list"] = day_share_return_score_list
  167. feature_dict["day_share_score_list"] = day_share_score_list
  168. feature_dict["day_return_rate_list"] = day_return_rate_list
  169. feature_dict["day_ctr_score_list"] = day_ctr_score_list
  170. # feature_dict["day_play_pv_list"] = day_play_pv_list
  171. # feature_dict["day_play_users_list"] = day_play_users_list
  172. # feature_dict["day_return_users_list"] = day_return_users_list
  173. # feature_dict["day_share_pv_list"] = day_share_pv_list
  174. # feature_dict["day_view_pv_list"] = day_view_pv_list
  175. # feature_dict["day_view_users_list"] = day_view_users_list
  176. # feature_dict["day_share_users_list"] = day_share_users
  177. feature_dict["hour_rov_list"] = hour_rov_list
  178. feature_dict["hour_share_return_score_list"] = hour_share_return_score_list
  179. feature_dict["hour_share_score_list"] = hour_share_score_list
  180. feature_dict["hour_return_rate_list"] = hour_return_rate_list
  181. feature_dict["hour_ctr_score_list"] = hour_ctr_score_list
  182. feature_dict["city_code"] = city_list
  183. feature_dict["province_code"] = province_list
  184. return feature_dict
  185. def insert_static_default_fea(day_ctr_score_list, day_play_pv_list, day_play_users_list, day_return_rate_list,
  186. day_return_users_list, day_rov_list, day_share_pv_list, day_share_return_score_list,
  187. day_share_score_list, day_share_users, day_view_pv_list, day_view_users_list):
  188. day_rov_list.append(0.0)
  189. day_share_return_score_list.append(0.0)
  190. day_share_score_list.append(0.0)
  191. day_return_rate_list.append(0.0)
  192. day_ctr_score_list.append(0.0)
  193. # day_view_users_list.append(0)
  194. # day_view_pv_list.append(0)
  195. # day_play_users_list.append(0)
  196. # day_play_pv_list.append(0)
  197. # day_share_users.append(0)
  198. # day_share_pv_list.append(0)
  199. # day_return_users_list.append(0)
  200. def get_tf_serving_sores(feature_dict):
  201. #for k, v in feature_dict:
  202. inputs_data = {
  203. "mid": feature_dict["mid_list"],
  204. "videoid": feature_dict["videoid_list"],
  205. "apptype": feature_dict["apptype_list"],
  206. "pagesource": feature_dict["pagesource_list"],
  207. "versioncode": feature_dict["versioncode_list"],
  208. "machineinfo_brand": feature_dict["machineinfo_brand_list"],
  209. "machineinfo_model": feature_dict["machineinfo_model_list"],
  210. "recommendsource": feature_dict["recommendsource_list"],
  211. "machineinfo_platform": feature_dict["machineinfo_platform_list"],
  212. "sencetype": feature_dict["sencetype_list"],
  213. "day_rov": feature_dict["day_rov_list"],
  214. "day_share_return_score": feature_dict["day_share_return_score_list"],
  215. "day_share_score": feature_dict["day_share_score_list"],
  216. "day_return_rate": feature_dict["day_return_rate_list"],
  217. "day_ctr_score": feature_dict["day_ctr_score_list"],
  218. # "day_play_pv": feature_dict["day_play_pv_list"],
  219. # "day_play_users": feature_dict["day_play_users_list"],
  220. # "day_share_pv": feature_dict["day_share_pv_list"],
  221. # "day_return_users": feature_dict["day_return_users_list"],
  222. # "day_share_users": feature_dict["day_share_users_list"],
  223. # "day_view_pv": feature_dict["day_view_pv_list"],
  224. # "day_view_users":feature_dict["day_view_users_list"],
  225. "hour_rov": feature_dict["hour_rov_list"],
  226. "hour_share_score": feature_dict["hour_share_score_list"],
  227. #"hour_share_return_score": feature_dict["hour_share_return_score_list"],
  228. #"hour_return_rate": feature_dict["hour_return_rate_list"],
  229. #"hour_ctr_score": feature_dict["hour_ctr_score_list"],
  230. "city_code": feature_dict['city_code'],
  231. "province_code": feature_dict['province_code']
  232. }
  233. request_data_dict= {}
  234. request_data_dict["inputs"] = inputs_data
  235. #print(request_data_dict)
  236. request_data= json.dumps(request_data_dict)
  237. #print(request_data)
  238. # 调用http接口
  239. result = request_post_data(config_.TF_SERVING_URL,request_data, timeout=(0.1, 1))
  240. # print("result:", result)
  241. if result is None:
  242. print("result is None")
  243. log_.info('call tf serving error,types: {}')
  244. return []
  245. #print(result)
  246. return result