|  | @@ -2,84 +2,191 @@
 | 
											
												
													
														|  |  @author: luojunhui
 |  |  @author: luojunhui
 | 
											
												
													
														|  |  调用接口在微信内搜索视频
 |  |  调用接口在微信内搜索视频
 | 
											
												
													
														|  |  """
 |  |  """
 | 
											
												
													
														|  | -import json
 |  | 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  from applications.search import *
 |  |  from applications.search import *
 | 
											
												
													
														|  | -from applications.static.config import gh_id_dict
 |  | 
 | 
											
												
													
														|  | 
 |  | +from applications.static.config import gh_id_dict, ab_test_config
 | 
											
												
													
														|  |  from applications.functions.log import logging
 |  |  from applications.functions.log import logging
 | 
											
												
													
														|  |  from applications.functions.video_item import video_mq_sender
 |  |  from applications.functions.video_item import video_mq_sender
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -def recall_search_video(video_path, title, trace_id):
 |  | 
 | 
											
												
													
														|  | 
 |  | +class SearchABTest(object):
 | 
											
												
													
														|  |      """
 |  |      """
 | 
											
												
													
														|  | -    search and send msg to ETL
 |  | 
 | 
											
												
													
														|  | -    :param trace_id:
 |  | 
 | 
											
												
													
														|  | -    :param title:  视频标题
 |  | 
 | 
											
												
													
														|  | -    :param video_path:  视频路径
 |  | 
 | 
											
												
													
														|  | -    :return:
 |  | 
 | 
											
												
													
														|  | 
 |  | +    搜索策略实验方案
 | 
											
												
													
														|  |      """
 |  |      """
 | 
											
												
													
														|  | -    with open(video_path, encoding='utf-8') as f:
 |  | 
 | 
											
												
													
														|  | -        my_obj = json.loads(f.read())
 |  | 
 | 
											
												
													
														|  | -    if my_obj:
 |  | 
 | 
											
												
													
														|  | -        wx_result = wx_search(keys=title)
 |  | 
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    ori_title = None
 | 
											
												
													
														|  | 
 |  | +    article_summary = None
 | 
											
												
													
														|  | 
 |  | +    article_keys = None
 | 
											
												
													
														|  | 
 |  | +    gh_id = None
 | 
											
												
													
														|  | 
 |  | +    trace_id = None
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    def __init__(self, info, gh_id):
 | 
											
												
													
														|  | 
 |  | +        SearchABTest.set_class_properties(info, gh_id)
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    @classmethod
 | 
											
												
													
														|  | 
 |  | +    def set_class_properties(cls, info, gh_id):
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        初始化搜索策略实验类
 | 
											
												
													
														|  | 
 |  | +        :param info: kimi 挖掘的基本信息
 | 
											
												
													
														|  | 
 |  | +        :param gh_id: 公众号账号 id
 | 
											
												
													
														|  | 
 |  | +        :return:
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        cls.ori_title = info["ori_title"]
 | 
											
												
													
														|  | 
 |  | +        cls.article_summary = info["content_title"]
 | 
											
												
													
														|  | 
 |  | +        cls.article_keys = info["content_keys"]
 | 
											
												
													
														|  | 
 |  | +        cls.trace_id = info["trace_id"]
 | 
											
												
													
														|  | 
 |  | +        cls.gh_id = gh_id
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    @classmethod
 | 
											
												
													
														|  | 
 |  | +    def ab_0(cls):
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        默认搜索逻辑
 | 
											
												
													
														|  | 
 |  | +        :return:
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        wx_result = wx_search(keys=cls.ori_title)
 | 
											
												
													
														|  |          if wx_result:
 |  |          if wx_result:
 | 
											
												
													
														|  | -            return {
 |  | 
 | 
											
												
													
														|  | -                "platform": "wx_search",
 |  | 
 | 
											
												
													
														|  | -                "result": wx_result[0]
 |  | 
 | 
											
												
													
														|  | -            }
 |  | 
 | 
											
												
													
														|  | 
 |  | +            return {"platform": "wx_search", "result": wx_result[0]}
 | 
											
												
													
														|  |          else:
 |  |          else:
 | 
											
												
													
														|  |              logging(
 |  |              logging(
 | 
											
												
													
														|  |                  code="7001",
 |  |                  code="7001",
 | 
											
												
													
														|  | -                info="通过微信搜索失败---{}".format(title),
 |  | 
 | 
											
												
													
														|  | -                trace_id=trace_id
 |  | 
 | 
											
												
													
														|  | 
 |  | +                info="通过微信搜索失败---{}".format(cls.ori_title),
 | 
											
												
													
														|  | 
 |  | +                trace_id=cls.trace_id,
 | 
											
												
													
														|  |              )
 |  |              )
 | 
											
												
													
														|  |              # 微信搜不到的话,采用好看视频搜索
 |  |              # 微信搜不到的话,采用好看视频搜索
 | 
											
												
													
														|  | -            baidu_result = hksp_search(key=title)
 |  | 
 | 
											
												
													
														|  | 
 |  | +            baidu_result = hksp_search(key=cls.ori_title)
 | 
											
												
													
														|  |              if baidu_result:
 |  |              if baidu_result:
 | 
											
												
													
														|  | -                return {
 |  | 
 | 
											
												
													
														|  | -                    "platform": "baidu_search",
 |  | 
 | 
											
												
													
														|  | -                    "result": baidu_result[0]
 |  | 
 | 
											
												
													
														|  | -                }
 |  | 
 | 
											
												
													
														|  | 
 |  | +                return {"platform": "baidu_search", "result": baidu_result[0]}
 | 
											
												
													
														|  |              else:
 |  |              else:
 | 
											
												
													
														|  |                  # 若好看视频未搜到,则采用西瓜搜索
 |  |                  # 若好看视频未搜到,则采用西瓜搜索
 | 
											
												
													
														|  |                  logging(
 |  |                  logging(
 | 
											
												
													
														|  |                      code="7001",
 |  |                      code="7001",
 | 
											
												
													
														|  | -                    info="通过baidu搜索失败---{}".format(title),
 |  | 
 | 
											
												
													
														|  | -                    trace_id=trace_id
 |  | 
 | 
											
												
													
														|  | 
 |  | +                    info="通过baidu搜索失败---{}".format(cls.ori_title),
 | 
											
												
													
														|  | 
 |  | +                    trace_id=cls.trace_id,
 | 
											
												
													
														|  | 
 |  | +                )
 | 
											
												
													
														|  | 
 |  | +                return None
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    @classmethod
 | 
											
												
													
														|  | 
 |  | +    def ab_1(cls):
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        :return:
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        wx_result = wx_search(keys=cls.article_summary)
 | 
											
												
													
														|  | 
 |  | +        if wx_result:
 | 
											
												
													
														|  | 
 |  | +            return {"platform": "wx_search", "result": wx_result[0]}
 | 
											
												
													
														|  | 
 |  | +        else:
 | 
											
												
													
														|  | 
 |  | +            logging(
 | 
											
												
													
														|  | 
 |  | +                code="7001",
 | 
											
												
													
														|  | 
 |  | +                info="通过微信搜索失败---{}".format(cls.article_summary),
 | 
											
												
													
														|  | 
 |  | +                trace_id=cls.trace_id,
 | 
											
												
													
														|  | 
 |  | +            )
 | 
											
												
													
														|  | 
 |  | +            # 微信搜不到的话,采用好看视频搜索
 | 
											
												
													
														|  | 
 |  | +            baidu_result = hksp_search(key=cls.article_summary)
 | 
											
												
													
														|  | 
 |  | +            if baidu_result:
 | 
											
												
													
														|  | 
 |  | +                return {"platform": "baidu_search", "result": baidu_result[0]}
 | 
											
												
													
														|  | 
 |  | +            else:
 | 
											
												
													
														|  | 
 |  | +                # 若好看视频未搜到,则采用西瓜搜索
 | 
											
												
													
														|  | 
 |  | +                logging(
 | 
											
												
													
														|  | 
 |  | +                    code="7001",
 | 
											
												
													
														|  | 
 |  | +                    info="通过baidu搜索失败---{}".format(cls.article_summary),
 | 
											
												
													
														|  | 
 |  | +                    trace_id=cls.trace_id,
 | 
											
												
													
														|  |                  )
 |  |                  )
 | 
											
												
													
														|  |                  return None
 |  |                  return None
 | 
											
												
													
														|  | -                # xigua_result = xigua_search(title)
 |  | 
 | 
											
												
													
														|  | -                # if xigua_result:
 |  | 
 | 
											
												
													
														|  | -                #     return {
 |  | 
 | 
											
												
													
														|  | -                #         "platform": "xg_search",
 |  | 
 | 
											
												
													
														|  | -                #         "result": xigua_result[0]
 |  | 
 | 
											
												
													
														|  | -                #     }
 |  | 
 | 
											
												
													
														|  | -                # else:
 |  | 
 | 
											
												
													
														|  | -                #     logging(
 |  | 
 | 
											
												
													
														|  | -                #         code="7001",
 |  | 
 | 
											
												
													
														|  | -                #         info="通过西瓜搜索失败---{}".format(title),
 |  | 
 | 
											
												
													
														|  | -                #         trace_id=trace_id
 |  | 
 | 
											
												
													
														|  | -                #     )
 |  | 
 | 
											
												
													
														|  | -                #     return None
 |  | 
 | 
											
												
													
														|  | -    else:
 |  | 
 | 
											
												
													
														|  | -        logging(
 |  | 
 | 
											
												
													
														|  | -            code="7000",
 |  | 
 | 
											
												
													
														|  | -            info="标题--{}--kimi 挖掘数据失败".format(title),
 |  | 
 | 
											
												
													
														|  | -            trace_id=trace_id
 |  | 
 | 
											
												
													
														|  | -        )
 |  | 
 | 
											
												
													
														|  | -        return None
 |  | 
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +    @classmethod
 | 
											
												
													
														|  | 
 |  | +    def ab_2(cls):
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        ori_title + wx
 | 
											
												
													
														|  | 
 |  | +        :return:
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        wx_result = wx_search(keys=",".join(cls.article_keys))
 | 
											
												
													
														|  | 
 |  | +        if wx_result:
 | 
											
												
													
														|  | 
 |  | +            return {"platform": "wx_search", "result": wx_result[0]}
 | 
											
												
													
														|  | 
 |  | +        else:
 | 
											
												
													
														|  | 
 |  | +            logging(
 | 
											
												
													
														|  | 
 |  | +                code="7001",
 | 
											
												
													
														|  | 
 |  | +                info="通过微信搜索失败---{}".format(",".join(cls.article_keys)),
 | 
											
												
													
														|  | 
 |  | +                trace_id=cls.trace_id,
 | 
											
												
													
														|  | 
 |  | +            )
 | 
											
												
													
														|  | 
 |  | +            # 微信搜不到的话,采用好看视频搜索
 | 
											
												
													
														|  | 
 |  | +            baidu_result = hksp_search(key=",".join(cls.article_keys))
 | 
											
												
													
														|  | 
 |  | +            if baidu_result:
 | 
											
												
													
														|  | 
 |  | +                return {"platform": "baidu_search", "result": baidu_result[0]}
 | 
											
												
													
														|  | 
 |  | +            else:
 | 
											
												
													
														|  | 
 |  | +                # 若好看视频未搜到,则采用西瓜搜索
 | 
											
												
													
														|  | 
 |  | +                logging(
 | 
											
												
													
														|  | 
 |  | +                    code="7001",
 | 
											
												
													
														|  | 
 |  | +                    info="通过baidu搜索失败---{}".format(",".join(cls.article_keys)),
 | 
											
												
													
														|  | 
 |  | +                    trace_id=cls.trace_id,
 | 
											
												
													
														|  | 
 |  | +                )
 | 
											
												
													
														|  | 
 |  | +                return None
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    @classmethod
 | 
											
												
													
														|  | 
 |  | +    def ab_3(cls):
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        article_summary + baidu
 | 
											
												
													
														|  | 
 |  | +        :return:
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        result = hksp_search(key=cls.article_summary)
 | 
											
												
													
														|  | 
 |  | +        return {"platform": "baidu_search", "result": result[0] if result else []}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    @classmethod
 | 
											
												
													
														|  | 
 |  | +    def ab_4(cls):
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        article_summary + weixin
 | 
											
												
													
														|  | 
 |  | +        :return:
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        result = wx_search(keys=cls.article_summary)
 | 
											
												
													
														|  | 
 |  | +        return {"platform": "wx_search", "result": result[0] if result else []}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -def search_videos(video_path, title, trace_id, gh_id):
 |  | 
 | 
											
												
													
														|  | 
 |  | +    @classmethod
 | 
											
												
													
														|  | 
 |  | +    def ab_5(cls):
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        article_keys + weixin
 | 
											
												
													
														|  | 
 |  | +        :return:
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        result = wx_search(keys=",".join(cls.article_keys))
 | 
											
												
													
														|  | 
 |  | +        return {"platform": "wx_search", "result": result[0] if result else []}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    @classmethod
 | 
											
												
													
														|  | 
 |  | +    def ab_6(cls):
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        article_keys + baidu
 | 
											
												
													
														|  | 
 |  | +        :return:
 | 
											
												
													
														|  | 
 |  | +        """
 | 
											
												
													
														|  | 
 |  | +        result = hksp_search(key=",".join(cls.article_keys))
 | 
											
												
													
														|  | 
 |  | +        return {"platform": "baidu_search", "result": result[0] if result else []}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +async def search_videos(kimi_info, trace_id, gh_id):
 | 
											
												
													
														|  |      """
 |  |      """
 | 
											
												
													
														|  |      search and send msg to ETL
 |  |      search and send msg to ETL
 | 
											
												
													
														|  | -    :param gh_id:
 |  | 
 | 
											
												
													
														|  | -    :param video_path:
 |  | 
 | 
											
												
													
														|  | -    :param title:
 |  | 
 | 
											
												
													
														|  | 
 |  | +    :param kimi_info:
 | 
											
												
													
														|  | 
 |  | +    :param gh_id: 通过账号 id 来控制实验策略
 | 
											
												
													
														|  |      :param trace_id:
 |  |      :param trace_id:
 | 
											
												
													
														|  |      :return:
 |  |      :return:
 | 
											
												
													
														|  |      """
 |  |      """
 | 
											
												
													
														|  | -    recall_obj = recall_search_video(video_path, title, trace_id)
 |  | 
 | 
											
												
													
														|  | 
 |  | +    kimi_info["trace_id"] = trace_id
 | 
											
												
													
														|  | 
 |  | +    SearchAB = SearchABTest(info=kimi_info, gh_id=gh_id)
 | 
											
												
													
														|  | 
 |  | +    if ab_test_config.get(gh_id):
 | 
											
												
													
														|  | 
 |  | +        test_id = ab_test_config[gh_id]
 | 
											
												
													
														|  | 
 |  | +        if test_id == 0:
 | 
											
												
													
														|  | 
 |  | +            recall_obj = SearchAB.ab_0()
 | 
											
												
													
														|  | 
 |  | +        elif test_id == 1:
 | 
											
												
													
														|  | 
 |  | +            recall_obj = SearchAB.ab_1()
 | 
											
												
													
														|  | 
 |  | +        elif test_id == 2:
 | 
											
												
													
														|  | 
 |  | +            recall_obj = SearchAB.ab_2()
 | 
											
												
													
														|  | 
 |  | +        # elif test_id == 3:
 | 
											
												
													
														|  | 
 |  | +        #     recall_obj = SearchAB.ab_3()
 | 
											
												
													
														|  | 
 |  | +        # elif test_id == 4:
 | 
											
												
													
														|  | 
 |  | +        #     recall_obj = SearchAB.ab_4()
 | 
											
												
													
														|  | 
 |  | +        # elif test_id == 5:
 | 
											
												
													
														|  | 
 |  | +        #     recall_obj = SearchAB.ab_5()
 | 
											
												
													
														|  | 
 |  | +        # elif test_id == 6:
 | 
											
												
													
														|  | 
 |  | +        #     recall_obj = SearchAB.ab_6()
 | 
											
												
													
														|  | 
 |  | +        else:
 | 
											
												
													
														|  | 
 |  | +            recall_obj = {}
 | 
											
												
													
														|  | 
 |  | +    else:
 | 
											
												
													
														|  | 
 |  | +        recall_obj = SearchAB.ab_0()
 | 
											
												
													
														|  |      if recall_obj:
 |  |      if recall_obj:
 | 
											
												
													
														|  |          platform = recall_obj["platform"]
 |  |          platform = recall_obj["platform"]
 | 
											
												
													
														|  |          recall_video = recall_obj["result"]
 |  |          recall_video = recall_obj["result"]
 | 
											
										
											
												
													
														|  | @@ -88,17 +195,13 @@ def search_videos(video_path, title, trace_id, gh_id):
 | 
											
												
													
														|  |                  code="7002",
 |  |                  code="7002",
 | 
											
												
													
														|  |                  info="视频搜索成功, 搜索平台为--{}".format(platform),
 |  |                  info="视频搜索成功, 搜索平台为--{}".format(platform),
 | 
											
												
													
														|  |                  trace_id=trace_id,
 |  |                  trace_id=trace_id,
 | 
											
												
													
														|  | -                data=recall_video
 |  | 
 | 
											
												
													
														|  | 
 |  | +                data=recall_video,
 | 
											
												
													
														|  |              )
 |  |              )
 | 
											
												
													
														|  | -            video_mq_sender(
 |  | 
 | 
											
												
													
														|  | 
 |  | +            await video_mq_sender(
 | 
											
												
													
														|  |                  video_obj=recall_video,
 |  |                  video_obj=recall_video,
 | 
											
												
													
														|  |                  user=gh_id_dict.get(gh_id),
 |  |                  user=gh_id_dict.get(gh_id),
 | 
											
												
													
														|  |                  trace_id=trace_id,
 |  |                  trace_id=trace_id,
 | 
											
												
													
														|  | -                platform=platform
 |  | 
 | 
											
												
													
														|  | 
 |  | +                platform=platform,
 | 
											
												
													
														|  |              )
 |  |              )
 | 
											
												
													
														|  |      else:
 |  |      else:
 | 
											
												
													
														|  | -        logging(
 |  | 
 | 
											
												
													
														|  | -            code="7003",
 |  | 
 | 
											
												
													
														|  | -            info="视频搜索失败",
 |  | 
 | 
											
												
													
														|  | -            trace_id=trace_id
 |  | 
 | 
											
												
													
														|  | -        )
 |  | 
 | 
											
												
													
														|  | 
 |  | +        logging(code="7003", info="视频搜索失败", trace_id=trace_id)
 |