PainterBase.py 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. import redis
  2. import time as time
  3. import logging
  4. import json
  5. from .DataStream import span_days, day_stamp, span_days, time_border, calc_interval
  6. import logging
  7. logger = logging.getLogger('PainterBase')
  8. class PainterBase(object):
  9. def __init__(self):
  10. self._redis_client = None
  11. pass
  12. def set_redis(self, rhost, rport):
  13. pool = redis.ConnectionPool(host=rhost, port=rport)
  14. self._redis_client = redis.Redis(connection_pool=pool)
  15. pass
  16. def redis_client(self):
  17. return self._redis_client
  18. def calc_time(self, reader, start_time: int, end_time: int):
  19. if end_time is None:
  20. end_time = int(time.time())
  21. end_time = reader.near_stamp(end_time, False)
  22. if end_time is None:
  23. raise Exception('data is empty')
  24. if start_time is None or start_time > end_time:
  25. start_time = end_time - 7200
  26. start_time = reader.near_stamp(start_time, True)
  27. if start_time is None:
  28. raise Exception('data is empty')
  29. stime = lambda t: time.strftime('%d-%H:%M:%S', time.localtime(t))
  30. logger.debug("near_stamp start_time %d , %s end_time=%s", start_time, stime(start_time), stime(end_time))
  31. interval = calc_interval(start_time, end_time)
  32. start_time = time_border(interval, start_time, True)
  33. end_time = time_border(interval, end_time, False)
  34. logger.debug("time_border start_time %d , %s end_time=%s", start_time, stime(start_time), stime(end_time))
  35. days = span_days(start_time, end_time)
  36. stime = lambda t: time.strftime('%d-%H:%M:%S', time.localtime(t))
  37. sdays = [stime(day) for day in days]
  38. logger.debug(sdays)
  39. return days, start_time, end_time, interval