test_run_local.py 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. # -*- coding: utf-8 -*-
  2. # @Time : 2024/6/11
  3. # @Author : 魏志亮
  4. import datetime
  5. import sys
  6. import traceback
  7. from os import *
  8. def get_exec_data(batch_no=None, read_type=None, run_count=1):
  9. if batch_no and read_type:
  10. data = get_data_by_batch_no_and_type(batch_no, read_type)
  11. if data is None:
  12. raise ValueError(f"未找到批次号:{batch_no},类型:{read_type}")
  13. else:
  14. data = get_batch_exec_data(run_count)
  15. if data is None:
  16. trans_print("当前有任务在执行")
  17. sys.exit(0)
  18. elif len(data.keys()) == 0:
  19. trans_print("当前无任务")
  20. sys.exit(0)
  21. return data
  22. def run(data: dict = dict(), save_db=False, step=0, end=4):
  23. exec_process = None
  24. if data['transfer_type'] in ['second', 'minute']:
  25. exec_process = MinSecTrans(data=data, save_db=save_db, step=step, end=end)
  26. if data['transfer_type'] in ['fault', 'warn']:
  27. exec_process = FaultWarnTrans(data=data, save_db=save_db, step=step, end=end)
  28. if exec_process is None:
  29. raise Exception("No exec process")
  30. exec_process.run()
  31. if __name__ == '__main__':
  32. from utils.conf.read_conf import yaml_conf, read_conf
  33. env = 'prod'
  34. if len(sys.argv) >= 2:
  35. env = sys.argv[1]
  36. conf_path = path.abspath(f"./conf/etl_config_{env}.yaml")
  37. environ['ETL_CONF'] = conf_path
  38. yaml_config = yaml_conf(conf_path)
  39. environ['env'] = env
  40. run_count = int(read_conf(yaml_config, "run_batch_count", 1))
  41. from utils.log.trans_log import trans_print
  42. from service.plt_service import get_batch_exec_data, get_data_by_batch_no_and_type
  43. from etl.wind_power.fault_warn.FaultWarnTrans import FaultWarnTrans
  44. from etl.wind_power.min_sec.MinSecTrans import MinSecTrans
  45. from etl.wind_power.wave.WaveTrans import WaveTrans
  46. begin = datetime.datetime.now()
  47. try:
  48. exec_process = WaveTrans(1, 'WOF091200030',
  49. r'/data/download/collection_data/1进行中/张崾先风电场-陕西-华电/收资数据/振动/CMSFTPServer/ZYXFDC2')
  50. exec_process.run()
  51. except Exception as e:
  52. trans_print(traceback.format_exc())
  53. trans_print("执行结束,总耗时:", datetime.datetime.now() - begin)