app.py 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. """General function module"""
  2. import random
  3. from datetime import datetime, timedelta
  4. # libraries and data
  5. import matplotlib.pyplot as plt
  6. import matplotlib.dates as mdates
  7. import pandas as pd
  8. from pandas.plotting import register_matplotlib_converters
  9. from telegram import ParseMode
  10. from app import LOGGER, SCHEDULER, TELEGRAM_BOT, jobs, api, database
  11. register_matplotlib_converters()
  12. def check_resources(state_id, capital_id, resource_id, do_refill):
  13. """Check resources and refill if necessary"""
  14. regions = api.download_resources(state_id, resource_id)
  15. print_resources(regions)
  16. database.save_resources(state_id, regions, resource_id)
  17. if do_refill and need_refill(regions, 25):
  18. max_seconds = max_refill_seconds(regions, 25, 900)
  19. random_seconds = random.randint(0, max_seconds)
  20. random_time_delta = timedelta(seconds=random_seconds)
  21. scheduled_date = datetime.now() + random_time_delta
  22. job_id = 'refill_{}_{}'.format(capital_id, resource_id)
  23. LOGGER.info(
  24. 'Refil resource %s at %s (%s minutes)',
  25. resource_id,
  26. scheduled_date,
  27. round(random_time_delta.seconds / 60)
  28. )
  29. job = SCHEDULER.get_job(job_id)
  30. if not job:
  31. SCHEDULER.add_job(
  32. jobs.refill_resource,
  33. 'date',
  34. args=[state_id, capital_id, resource_id],
  35. id=job_id,
  36. run_date=scheduled_date
  37. )
  38. def print_resources(regions):
  39. """print resources"""
  40. if regions:
  41. print('region expl max D left c % t %')
  42. for region in regions.values():
  43. region['explored_percentage'] = 100 / region['maximum'] * region['explored']
  44. region['total_left'] = region['explored'] + region['limit_left']
  45. region['total_percentage'] = 100 / 2500 * region['total_left']
  46. print('{:25}: {:7.2f}{:4}{:4}{:5}{:7.2f}{:7.2f}'.format(
  47. region['region_name'],
  48. region['explored'],
  49. region['maximum'],
  50. region['deep_exploration'],
  51. region['limit_left'],
  52. region['explored_percentage'],
  53. region['total_percentage'],
  54. ))
  55. else:
  56. LOGGER.error('no region to print data')
  57. def need_refill(regions, limit):
  58. """Check if refill is needed"""
  59. for region in regions.values():
  60. percentage = 100 / region['maximum'] * region['explored']
  61. if percentage < limit and region['limit_left']:
  62. return True
  63. return False
  64. def max_refill_seconds(regions, limit, max_time):
  65. """Give random seconds for next refill"""
  66. lowest_percentage = limit
  67. for region in regions.values():
  68. percentage = 100 / region['maximum'] * region['explored']
  69. if percentage < lowest_percentage:
  70. lowest_percentage = percentage
  71. return int(max_time / limit * lowest_percentage)
  72. def send_telegram_update(state_id, group_id, resource_type):
  73. """Send mine update to telegram"""
  74. message = database.get_work_percentage(state_id, resource_type, datetime.utcnow(), 1, 1)
  75. if message:
  76. print(message)
  77. TELEGRAM_BOT.sendMessage(
  78. chat_id=group_id,
  79. text='```\n{}```'.format(message),
  80. parse_mode=ParseMode.MARKDOWN
  81. )
  82. else:
  83. LOGGER.error('no data for Telegram message')
  84. def graph():
  85. """make graph"""
  86. date = datetime.now() + timedelta(1)
  87. region_4001 = database.get_resources(4001, date, 0)
  88. region_4002 = database.get_resources(4002, date, 0)
  89. region_4003 = database.get_resources(4003, date, 0)
  90. region_4004 = database.get_resources(4004, date, 0)
  91. region_4008 = database.get_resources(4008, date, 0)
  92. # resource_tmp = np.random.randn(2499)+range(2500, 1, -1)
  93. # Make a data frame
  94. data_frame = pd.DataFrame({
  95. # 'x': range(1, 2500),
  96. # '4001': resource_tmp,
  97. 'x': list(region_4001.keys()),
  98. 'Northern Netherlands': list(region_4001.values()),
  99. 'Eastern Netherlands': list(region_4002.values()),
  100. 'Western Netherlands': list(region_4003.values()),
  101. 'Southern Netherlands': list(region_4004.values()),
  102. 'Amsterdam': list(region_4008.values()),
  103. })
  104. major_fmt = mdates.DateFormatter('%m-%d %H:%M')
  105. fig, ax = plt.subplots()
  106. ax.xaxis.set_major_formatter(major_fmt)
  107. fig.autofmt_xdate()
  108. end_date_time = date.replace(hour=19, minute=0, second=0, microsecond=0)
  109. start_date_time = end_date_time - timedelta(hours=24)
  110. ax.set_xlim([start_date_time, end_date_time])
  111. ax.set_ylim([0, 2500])
  112. # style
  113. plt.style.use('seaborn-darkgrid')
  114. # create a color palette
  115. palette = plt.get_cmap('Set1')
  116. # multiple line plot
  117. num = 0
  118. for column in data_frame.drop('x', axis=1):
  119. num += 1
  120. plt.plot(
  121. data_frame['x'],
  122. data_frame[column],
  123. marker='',
  124. color=palette(num),
  125. linewidth=1,
  126. alpha=0.9,
  127. label=column
  128. )
  129. # Add legend
  130. plt.legend(loc=3, ncol=1)
  131. # plt.setp(plt.xticks()[1], rotation=30, ha='right')
  132. # Add titles
  133. plt.title(
  134. 'Resource limit left | {}'.format(date.strftime('%Y-%m-%d')),
  135. loc='left',
  136. fontsize=12,
  137. fontweight=1
  138. )
  139. plt.xlabel("Time")
  140. plt.ylabel("Resources")
  141. plt.savefig('foo.png')