Browse Source

xiaoniaogao author etl

ehlxr 1 year ago
parent
commit
46e2dec5b6
1 changed files with 20 additions and 6 deletions
  1. 20 6
      xiaoniangao/xiaoniangao_author/xiaoniangao_author_scheduling.py

+ 20 - 6
xiaoniangao/xiaoniangao_author/xiaoniangao_author_scheduling.py

@@ -10,6 +10,8 @@ import time
 from hashlib import md5
 import requests
 import urllib3
+
+from common.mq import MQ
 sys.path.append(os.getcwd())
 from common.common import Common
 from common.scheduling_db import MysqlHelper
@@ -31,6 +33,7 @@ class XiaoniangaoAuthorScheduling:
     # 获取个人主页视频
     @classmethod
     def get_videoList(cls, log_type, crawler, rule_dict, user_dict, env):
+        mq = MQ(topic_name="topic_crawler_etl_" + env)
         next_t = -1
         while True:
             url = "https://kapi-xng-app.xiaoniangao.cn/v1/album/user_public"
@@ -141,12 +144,23 @@ class XiaoniangaoAuthorScheduling:
                             Common.logger(log_type, crawler).info('视频已下载\n')
                             Common.logging(log_type, crawler, env, '视频已下载\n')
                         else:
-                            cls.download_publish(log_type=log_type,
-                                                 crawler=crawler,
-                                                 video_dict=video_dict,
-                                                 rule_dict=rule_dict,
-                                                 user_dict=user_dict,
-                                                 env=env)
+                            # cls.download_publish(log_type=log_type,
+                            #                      crawler=crawler,
+                            #                      video_dict=video_dict,
+                            #                      rule_dict=rule_dict,
+                            #                      user_dict=user_dict,
+                            #                      env=env)
+                            video_dict["out_user_id"] = video_dict["profile_id"]
+                            video_dict["platform"] = crawler
+                            video_dict["strategy"] = log_type
+                            video_dict["out_video_id"] = video_dict["video_id"]
+                            video_dict["width"] = video_dict["video_width"]
+                            video_dict["height"] = video_dict["video_height"]
+                            video_dict["crawler_rule"] = json.dumps(rule_dict)
+                            video_dict["user_id"] = user_dict["uid"]
+                            video_dict["publish_time"] = video_dict["publish_time_str"]
+
+                            mq.send_msg(video_dict)
                     except Exception as e:
                         Common.logger(log_type, crawler).error(f"抓取单条视频异常:{e}\n")
                         Common.logging(log_type, crawler, env, f"抓取单条视频异常:{e}\n")