app.py 5.4 KB

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