Advertisement
Nika57

Untitled

Feb 14th, 2020
170
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 2.68 KB | None | 0 0
  1. # !/usr/bin/python
  2. # -*- coding: utf-8 -*-
  3.  
  4. import dash
  5. import dash_core_components as dcc
  6. import dash_html_components as html
  7.  
  8. import plotly.graph_objs as go
  9.  
  10. import pandas as pd
  11.  
  12. #задаем данные для отрисовки
  13. from sqlalchemy import create_engine
  14.  
  15. # пример подключения к базе данных для Postresql
  16. # db_config = {'user': 'my_user',
  17. # 'pwd': 'my_user_password',
  18. # 'host': 'localhost',
  19. # 'port': 5432,
  20. # 'db': 'games'}
  21. # engine = create_engine('postgresql://{}:{}@{}:{}/{}'.format(db_config['user'],
  22. # db_config['pwd'],
  23. # db_config['host'],
  24. # db_config['port'],
  25. # db_config['db']))
  26. # пример подключения к базе данных для Sqlite
  27. engine = create_engine('sqlite:////db/games.db', echo = False)
  28.  
  29. # получаем сырые данные
  30. query = '''
  31. SELECT * FROM data_raw
  32. '''
  33. games_raw = pd.io.sql.read_sql(query, con = engine)
  34.  
  35. # формируем данные для отчета
  36. games_grouped = (games_raw.groupby(['genre', 'year_of_release'])
  37. .agg({'name':'count'})
  38. .reset_index()
  39. .rename(columns = {'name':'Games Released'})
  40. )
  41.  
  42. # формируем графики для отрисовки
  43. data_games_by_year = []
  44. for genre in games_grouped['genre'].unique():
  45. current = games_grouped.query('genre == @genre')
  46. data_games_by_year += [go.Scatter(x = current['Year_of_Release'],
  47. y = current['Games Released'],
  48. mode = 'lines',
  49. stackgroup = 'one',
  50. name = genre)]
  51.  
  52.  
  53. # задаем лейаут
  54. external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
  55. app = dash.Dash(__name__, external_stylesheets=external_stylesheets,compress=False)
  56. app.layout = html.Div(children=[
  57.  
  58. # формируем html
  59. html.H1(children = 'Выпуск игр по годам'),
  60.  
  61. dcc.Graph(
  62. figure = {'data': data_games_by_year,
  63. 'layout': go.Layout(xaxis = {'title': 'Год'},
  64. yaxis = {'title': 'Выпущенные игры'})
  65. },
  66. id = 'games_by_year'
  67. ),
  68.  
  69. ])
  70.  
  71. # описываем логику дашборда
  72. if __name__ == '__main__':
  73. app.run_server(host='0.0.0.0', port=3000)
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement