X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=main.py;h=856d449fc16cf94263c81ad45b11bcb406a12ce0;hb=83c698c925db9dcb2d347c2a625de88d85cfeb21;hp=dcbc2a34c197e6540d8420cfb219d8152bdfa8c6;hpb=1f117ac79e10c3c9728d3b267d134dec2a165603;p=perso%2FImmae%2FProjets%2FCryptomonnaies%2FCryptoportfolio%2FTrader.git diff --git a/main.py b/main.py index dcbc2a3..856d449 100644 --- a/main.py +++ b/main.py @@ -117,6 +117,8 @@ def parse_args(argv): parser.add_argument("--action", action='append', help="Do a different action than trading (add several times to chain)") + parser.add_argument("--parallel", action='store_true', default=True, dest="parallel") + parser.add_argument("--no-parallel", action='store_false', dest="parallel") args = parser.parse_args(argv) @@ -126,18 +128,28 @@ def parse_args(argv): return args +def process(market_config, user_id, report_path, args): + try: + market.Market\ + .from_config(market_config, debug=args.debug, user_id=user_id, report_path=report_path)\ + .process(args.action, before=args.before, after=args.after) + except Exception as e: + print("{}: {}".format(e.__class__.__name__, e)) + def main(argv): args = parse_args(argv) pg_config, report_path = parse_config(args.config) - for market_config, user_id in fetch_markets(pg_config, args.user): - try: - market.Market\ - .from_config(market_config, debug=args.debug, user_id=user_id, report_path=report_path)\ - .process(args.action, before=args.before, after=args.after) - except Exception as e: - print("{}: {}".format(e.__class__.__name__, e)) + if args.parallel: + import threading + market.Portfolio.start_worker() + + for market_config, user_id in fetch_markets(pg_config, args.user): + threading.Thread(target=process, args=[market_config, user_id, report_path, args]).start() + else: + for market_config, user_id in fetch_markets(pg_config, args.user): + process(market_config, user_id, report_path, args) if __name__ == '__main__': # pragma: no cover main(sys.argv[1:])