alg_recsys_recall_shield_videos.py 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. # -*- coding: utf-8 -*-
  2. import traceback
  3. from config import set_config
  4. from log import Log
  5. from utils import execute_sql_from_odps
  6. from db_helper import RedisHelper
  7. import datetime
  8. config_, _ = set_config()
  9. log_ = Log()
  10. redis_helper = RedisHelper()
  11. table = "loghubods.special_area_recommend_limit"
  12. RISK_SHIELD_FILTER_VIDEO_V1_STR = "RISK_SHIELD_FILTER_VIDEO_V1_STR"
  13. def get_special_area_limit_videos():
  14. """获取特殊地域屏蔽视频并存入redis"""
  15. try:
  16. # 获取特殊地域屏蔽视频
  17. sql = "SELECT videoid FROM {}.{};".format(config_.PROJECT_SPECIAL_AREA_LIMIT,
  18. config_.TABLE_SPECIAL_AREA_LIMIT)
  19. print("sql:"+sql)
  20. records = execute_sql_from_odps(project=config_.PROJECT_SPECIAL_AREA_LIMIT, sql=sql)
  21. video_id_list = []
  22. with records.open_reader() as reader:
  23. for record in reader:
  24. video_id = int(record['videoid'])
  25. video_id_list.append(video_id)
  26. log_.info(f"special area limit videos count = {len(video_id_list)}")
  27. log_.info("videos = {}".format(",".join([str(i) for i in video_id_list])))
  28. # 存入redis
  29. if len(video_id_list) > 0:
  30. value = ",".join([str(i) for i in video_id_list])
  31. redis_helper.set_data_to_redis(key_name=RISK_SHIELD_FILTER_VIDEO_V1_STR, value=value,
  32. expire_time=3600*24 * 7)
  33. # redis_helper.del_keys(key_name=config_.SPECIAL_AREA_LIMIT_KEY_NAME)
  34. # redis_helper.add_data_with_set(key_name=config_.SPECIAL_AREA_LIMIT_KEY_NAME, values=video_id_list,
  35. # expire_time=25 * 3600)
  36. except Exception as e:
  37. log_.error(str(e) + str(traceback.format_exc()))
  38. def main():
  39. log_.info("开始执行:" + datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"))
  40. get_special_area_limit_videos()
  41. expire_time = 3600*24 * 30
  42. key = "RISK_SHIELD_FILTER_RULE_V1_JSON"
  43. value = "{\"2\": []}"
  44. redis_helper.set_data_to_redis(key, value, expire_time)
  45. value_get = redis_helper.get_data_from_redis(key_name=key)
  46. print('key:', key, type(key))
  47. print('value_get:', value_get, type(value_get))
  48. key = "RISK_SHIELD_FILTER_EXPANSION_FACTOR_INT"
  49. value = "10"
  50. redis_helper.set_data_to_redis(key, value, expire_time)
  51. value_get = redis_helper.get_data_from_redis(key_name=key)
  52. print('key:', key, type(key))
  53. print('value_get:', value_get, type(value_get))
  54. key = "RISK_SHIELD_FILTER_FLAG_BOOL"
  55. value = "True"
  56. redis_helper.set_data_to_redis(key, value, expire_time)
  57. value_get = redis_helper.get_data_from_redis(key_name=key)
  58. print('key:', key, type(key))
  59. print('value_get:', value_get, type(value_get))
  60. log_.info("完成执行:" + datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"))
  61. if __name__ == '__main__':
  62. main()
  63. # cd /root/zhangbo/rov-offline
  64. # python alg_recsys_recall_shield_videos.py