start_sync_amz.py 5.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. from sync_amz_data.tasks.account import AccountTask
  2. from sync_amz_data.settings import LOG_CONF
  3. import logging.config
  4. logging.config.dictConfig(LOG_CONF)
  5. from sync_amz_data.public.amz_ad_client import shop_infos
  6. from sync_amz_data.DataTransform.Data_ETL import Common_ETLMethod,SP_ETL,SB_ETL,SD_ETL
  7. from apscheduler.schedulers.blocking import BlockingScheduler
  8. def amz_report(AWS_CREDENTIALS,para=None):
  9. refresh_token = shop_infos(AWS_CREDENTIALS['profile_id'])['refresh_token']
  10. AWS_CREDENTIALS['refresh_token'] = refresh_token
  11. conn = SB_ETL(**AWS_CREDENTIALS).clickhouse_connect()
  12. sb_report = SB_ETL(**AWS_CREDENTIALS)
  13. sb_report.reportV3_purchasedAsinRecord_ETL(conn,params=para)
  14. sb_report.reportV2_campaignsRecord_ETL(conn,params=para)
  15. sb_report.reportV2_campaignsVideo_ETL(conn,params=para)
  16. sb_report.reportV2_adGroupsRecord_ETL(conn,params=para)
  17. sb_report.reportV2_adGroupsVideo_ETL(conn,params=para)
  18. sb_report.reportV2_adsRecord_ETL(conn,params=para)
  19. sb_report.reportV2_adsVideo_ETL(conn,params=para)
  20. sb_report.reportV2_keywordsRecord_ETL(conn,params=para)
  21. sb_report.reportV2_keywordsVideo_ETL(conn,params=para)
  22. sb_report.reportV2_placementRecord_ETL(conn,params=para)
  23. sb_report.reportV2_placementVideo_ETL(conn,params=para)
  24. sb_report.reportV2_searchtermsRecord_ETL(conn,params=para)
  25. sb_report.reportV2_searchtermsVideo_ETL(conn,params=para)
  26. sb_report.reportV2_targetsRecord_ETL(conn,params=para)
  27. sb_report.reportV2_targetsVideo_ETL(conn,params=para)
  28. conn.close()
  29. conn = SP_ETL(**AWS_CREDENTIALS).clickhouse_connect()
  30. sp_report = SP_ETL(**AWS_CREDENTIALS)
  31. sp_report.reportV3_campaign_spCampaignsETL(conn,params=para)
  32. sp_report.reportV3_adGroup_spCampaignsETL(conn,params=para)
  33. sp_report.reportV3_campaignPlacement_spCampaignsETL(conn,params=para)
  34. sp_report.reportV3_targeting_spTargetingETL(conn,params=para)
  35. sp_report.reportV3_searchTerm_spSearchTermETL(conn,params=para)
  36. sp_report.reportV3_advertiser_spAdvertisedProductETL(conn,params=para)
  37. sp_report.reportV3_asin_spPurchasedProductETL(conn,params=para)
  38. conn.close()
  39. conn = SD_ETL(**AWS_CREDENTIALS).clickhouse_connect()
  40. sd_report = SD_ETL(**AWS_CREDENTIALS)
  41. sd_report.reportV3_campaign_sdCampaigns_ETL(conn,params=para)
  42. sd_report.reportV3_campaignMT_sdCampaigns_ETL(conn,params=para)
  43. sd_report.reportV3_adgroup_sdAdGroup_ETL(conn,params=para)
  44. sd_report.reportV3_adgroupMT_sdAdGroup_ETL(conn,params=para)
  45. sd_report.reportV3_targeting_sdTargeting_ETL(conn,params=para)
  46. sd_report.reportV3_targetingMT_sdTargeting_ETL(conn,params=para)
  47. sd_report.reportV3_asin_sdPurchasedProduct_ETL(conn,params=para)
  48. sd_report.reportV3_advertiser_sdAdvertisedProduct_ETL(conn,params=para)
  49. # sd_report.reportV2_campaignsRecord_t2_ETL(conn,params=para)
  50. # sd_report.reportV2_campaignsRecord_t3_ETL(conn,params=para)
  51. # sd_report.reportV2_adGroupsRecord_t2_ETL(conn,params=para)
  52. # sd_report.reportV2_adGroupsRecord_t3_ETL(conn,params=para)
  53. # sd_report.reportV2_asins_t2_ETL(conn,params=para)
  54. # sd_report.reportV2_asins_t3_ETL(conn,params=para)
  55. # sd_report.reportV2_productAds_t2_ETL(conn,params=para)
  56. # sd_report.reportV2_productAds_t3_ETL(conn,params=para)
  57. # sd_report.reportV2_targets_t2_ETL(conn,params=para)
  58. # sd_report.reportV2_targets_t3_ETL(conn,params=para)
  59. # sd_report.reportV2_campaign_matchedTarget_t2_ETL(conn,params=para)
  60. # sd_report.reportV2_campaign_matchedTarget_t3_ETL(conn,params=para)
  61. # sd_report.reportV2_adGroups_matchedTarget_t2_ETL(conn,params=para)
  62. # sd_report.reportV2_adGroups_matchedTarget_t3_ETL(conn,params=para)
  63. # sd_report.reportV2_targets_matchedTarget_t2_ETL(conn,params=para)
  64. # sd_report.reportV2_targets_matchedTarget_t3_ETL(conn,params=para)
  65. conn.close()
  66. if __name__ == '__main__':
  67. # AccountTask("3006125408623189").do({"record": "portfolios"})
  68. AWS_CREDENTIALS = {
  69. 'lwa_client_id': 'amzn1.application-oa2-client.ebd701cd07854fb38c37ee49ec4ba109',
  70. 'refresh_token': "Atzr|IwEBIL4ur8kbcwRyxVu_srprAAoTYzujnBvA6jU-0SMxkRgOhGjYJSUNGKvw24EQwJa1jG5RM76mQD2P22AKSq8qSD94LddoXGdKDO74eQVYl0RhuqOMFqdrEZpp1p4bIR6_N8VeSJDHr7UCuo8FiabkSHrkq7tsNvRP-yI-bnpQv4EayPBh7YwHVX3hYdRbhxaBvgJENgCuiEPb35Q2-Z6w6ujjiKUAK2VSbCFpENlEfcHNsjDeY7RCvFlwlCoHj1IeiNIaFTE9yXFu3aEWlExe3LzHv6PZyunEi88QJSXKSh56Um0e0eEg05rMv-VBM83cAqc5POmZnTP1vUdZO8fQv3NFLZ-xU6e1WQVxVPi5Cyqk4jYhGf1Y9t98N654y0tVvw74qNIsTrB-8bGS0Uhfe24oBEWmzObvBY3zhtT1d42myGUJv4pMTU6yPoS83zhPKm3LbUDEpBA1hvvc_09jHk7vUEAuFB-UAZzlht2C1yklzQ",
  71. 'lwa_client_secret': 'cbf0514186db4df91e04a8905f0a91b605eae4201254ced879d8bb90df4b474d',
  72. 'profile_id': "3006125408623189"
  73. }
  74. refresh_token = shop_infos(AWS_CREDENTIALS['profile_id'])['refresh_token']
  75. AWS_CREDENTIALS['refresh_token'] = refresh_token
  76. timezone_ = Common_ETLMethod(**AWS_CREDENTIALS).timeZone()
  77. print(timezone_)
  78. sched = BlockingScheduler()
  79. sched.add_job(amz_report,'cron',hour=17,minute=0,second=0,timezone=timezone_, args=(AWS_CREDENTIALS, ))#,params={"startDate":"2023-11-04","endDate":"2023-11-04","date":"20231104"}
  80. sched.start()