대시 프레임 워크

이 장에서는 Dash 프레임 워크에 대해 자세히 설명합니다.

Dash는 분석 웹 애플리케이션을 구축하는 데 사용되는 오픈 소스 Python 프레임 워크입니다. 데이터 기반 애플리케이션의 개발을 단순화하는 강력한 라이브러리입니다. 웹 개발에 익숙하지 않은 Python 데이터 과학자에게 특히 유용합니다. 사용자는 대시를 사용하여 브라우저에서 멋진 대시 보드를 만들 수 있습니다.

Plotly.js, React 및 Flask 위에 구축 된 Dash는 드롭 다운, 슬라이더 및 그래프와 같은 최신 UI 요소를 분석 Python 코드에 직접 연결합니다.

대시 앱은 HTTP 요청을 통해 JSON 패킷을 사용하여 프런트 엔드 React 구성 요소와 통신하는 Flask 서버로 구성됩니다.

대시 애플리케이션은 순수하게 Python으로 작성되므로 HTML이나 JavaScript가 필요하지 않습니다.

대시 설정

Dash가 터미널에 아직 설치되지 않은 경우 아래 언급 된 Dash 라이브러리를 설치하십시오. 이러한 라이브러리는 개발 중이므로 자주 설치하고 업그레이드하십시오. Python 2 및 3도 지원됩니다.

  • pip install dash == 0.23.1 # 핵심 대시 백엔드
  • pip install dash-renderer == 0.13.0 # 대시 프런트 엔드
  • pip install dash-html-components == 0.11.0 # HTML 구성 요소
  • pip install dash-core-components == 0.26.0 # 강력한 구성 요소
  • pip install plotly == 3.1.0 # 플롯 그래프 라이브러리

모든 것이 제대로 작동하는지 확인하기 위해 간단한 dashApp.py 파일을 만들었습니다.

대시 또는 앱 레이아웃

대시 앱은 두 부분으로 구성됩니다. 첫 번째 부분은 기본적으로 응용 프로그램의 모양을 설명하는 응용 프로그램의 "레이아웃"입니다. 두 번째 부분에서는 응용 프로그램의 상호 작용에 대해 설명합니다.

핵심 구성 요소

레이아웃을 만들 수 있습니다. dash_html_components 그리고 dash_core_components도서관. Dash는 애플리케이션의 모든 시각적 구성 요소에 대한 Python 클래스를 제공합니다. JavaScript 및 React.js로 자체 구성 요소를 사용자 정의 할 수도 있습니다.

dash_core_components를 dcc로 가져 오기

dash_html_components를 html로 가져 오기

dash_html_components는 모든 HTML 태그 용이며 dash_core_components는 React.js로 빌드 된 상호 작용 용입니다.

위의 두 라이브러리를 사용하여 아래와 같이 코드를 작성해 보겠습니다.

app = dash.Dash()
app.layout = html.Div(children=[
   html.H1(children='Hello Dash'),
   html.Div(children='''Dash Framework: A web application framework for Python.''')

그리고 동등한 HTML 코드는 다음과 같습니다.

<div>
   <h1> Hello Dash </h1>
   <div> Dash Framework: A web application framework for Python. </div>
</div>

Simple Dash 앱 작성

파일에서 위에서 언급 한 라이브러리를 사용하여 대시에 간단한 예제를 작성하는 방법을 배웁니다. dashApp.py.

# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html

app = dash.Dash()
app.layout = html.Div(children=[
   html.H1(children='Hello Dash'),
   html.Div(children='''Dash Framework: A web application framework for Python.'''),
	
   dcc.Graph(
      id='example-graph',
      figure={
         'data': [
            {'x': [1, 2, 3], 'y': [4, 1, 2], 'type': 'bar', 'name': 'Delhi'},
            {'x': [1, 2, 3], 'y': [2, 4, 5], 'type': 'bar', 'name': u'Mumbai'},
         ],
         'layout': {
            'title': 'Dash Data Visualization'
         }
      }
   )
])

if __name__ == '__main__':
   app.run_server(debug=True)

Dash 앱 실행

Dash 앱을 실행하는 동안 다음 사항에 유의하십시오.

(MyDjangoEnv) C : \ Users \ rajesh \ Desktop \ MyDjango \ dash> python dashApp1.py

  • Flask 앱 "dashApp1"제공 (지연 로딩)

  • 환경 : 생산

    경고 : 프로덕션 환경에서 개발 서버를 사용하지 마십시오.

    대신 프로덕션 WSGI 서버를 사용하십시오.

  • 디버그 모드 : 켜기

  • stat로 다시 시작

  • 디버거가 활성화되었습니다!

  • 디버거 PIN : 130-303-947

  • 실행 중 http://127.0.0.1:8050/ (종료하려면 Ctrl + C를 누릅니다)

127.0.0.1 - - [12/Aug/2018 09:32:39] "GET / HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /_dash-layout HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /_dash-dependencies HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /favicon.ico HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:39:52] "GET /favicon.ico HTTP/1.1" 200 -

방문 http:127.0.0.1:8050/웹 브라우저에서. 다음과 같은 앱이 표시되어야합니다.

위의 프로그램에서 주목해야 할 몇 가지 중요한 사항은 다음과 같습니다.

  • 앱 레이아웃은 html.Div 및 dcc.Graph와 같은 "구성 요소"트리로 구성됩니다.

  • dash_html_components 라이브러리에는 모든 HTML 태그에 대한 구성 요소가 있습니다. html.H1 (children = 'Hello Dash') 구성 요소는 애플리케이션에서 <h1> Hello Dash </ h1> HTML 요소를 생성합니다.

  • 모든 구성 요소가 순수한 HTML은 아닙니다. dash_core_components는 React.js 라이브러리를 통해 JavaScript, HTML 및 CSS로 생성되는 대화 형 고급 구성 요소를 설명합니다.

  • 각 구성 요소는 키워드 속성을 통해 완전히 설명됩니다. 대시는 선언적입니다. 주로 이러한 속성을 통해 애플리케이션을 설명합니다.

  • 어린이 속성은 특별합니다. 관례 상 항상 첫 번째 속성이므로 생략 할 수 있습니다.

  • Html.H1 (children = 'Hello Dash')은 html.H1 ( 'Hello Dash')과 동일합니다.

  • 응용 프로그램의 글꼴은 여기에 표시되는 글꼴과 약간 다릅니다. 이 애플리케이션은 사용자 정의 CSS 스타일 시트를 사용하여 요소의 기본 스타일을 수정합니다. 사용자 정의 글꼴 스타일이 허용되지만 지금은 아래 URL 또는 원하는 URL을 추가 할 수 있습니다.

    app.css.append_css ({“external_url”:https://codepen.io/chriddyp/pen/bwLwgP.css}) 파일이이 예제와 동일한 모양과 느낌을 갖도록합니다.

HTML에 대한 추가 정보

dash_html_components 라이브러리에는 모든 HTML 태그에 대한 구성 요소 클래스와 모든 HTML 인수에 대한 키워드 인수가 포함되어 있습니다.

이전 앱 텍스트에서 구성 요소의 인라인 스타일을 추가해 보겠습니다.

# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html

app = dash.Dash()
colors = {
   'background': '#87D653',
   'text': '#ff0033'
}

app.layout = html.Div(style={'backgroundColor': colors['background']}, children=[
   html.H1(
      children='Hello Dash',
      style={
         'textAlign': 'center',
         'color': colors['text']
      }
   ),
	
   html.Div(children='Dash: A web application framework for Python.', style={
      'textAlign': 'center',
      'color': colors['text']
   }),
	
   dcc.Graph(
      id='example-graph-2',

      figure={
         'data': [
            {'x': [1, 2, 3], 'y': [4, 1, 2], 'type': 'bar', 'name': 'Delhi'},
            {'x': [1, 2, 3], 'y': [2, 4, 5], 'type': 'bar', 'name': u'Mumbai'},
         ],
         'layout': {
            'plot_bgcolor': colors['background'],
            'paper_bgcolor': colors['background'],
            'font': {
               'color': colors['text']
            }
         }
      }
   )
])

if __name__ == '__main__':
   app.run_server(debug=True)

위의 예에서는 style 속성을 사용하여 html.Div 및 html.H1 구성 요소의 인라인 스타일을 수정했습니다.

다음과 같이 대시 애플리케이션에서 렌더링됩니다.

dash_html_components와 HTML 속성 사이에는 몇 가지 주요 차이점이 있습니다.

  • Dash의 스타일 속성의 경우 사전 만 제공 할 수 있지만 HTML에서는 세미콜론으로 구분 된 문자열입니다.

  • 스타일 사전 키는 camelCased이므로 텍스트 정렬이 textalign.

  • Dash의 ClassName은 HTML 클래스 속성과 유사합니다.

  • 첫 번째 인수는 children 키워드 인수를 통해 지정된 HTML 태그의 하위입니다.

재사용 가능한 구성 요소

Python으로 마크 업을 작성하면 컨텍스트 나 언어를 전환하지 않고도 테이블과 같은 복잡한 재사용 가능한 구성 요소를 만들 수 있습니다.

다음은 pandas 데이터 프레임에서 "테이블"을 생성하는 빠른 예입니다.

import dash
import dash_core_components as dcc
import dash_html_components as html
import pandas as pd

df = pd.read_csv(
   'https://gist.githubusercontent.com/chriddyp/'
   'c78bf172206ce24f77d6363a2d754b59/raw/'
   'c353e8ef842413cae56ae3920b8fd78468aa4cb2/'
   'usa-agricultural-exports-2011.csv')
	
def generate_table(dataframe, max_rows=10):
   return html.Table(
      # Header
      [html.Tr([html.Th(col) for col in dataframe.columns])] +
      # Body
      [html.Tr([
         html.Td(dataframe.iloc[i][col]) for col in dataframe.columns
      ]) for i in range(min(len(dataframe), max_rows))]
   )
	
app = dash.Dash()
app.layout = html.Div(children=[
   html.H4(children='US Agriculture Exports (2011)'),
   generate_table(df)
])

if __name__ == '__main__':
   app.run_server(debug=True)

우리의 출력은 다음과 같습니다.

시각화에 대한 추가 정보

dash_core_components 라이브러리에는 Graph.

Graph는 오픈 소스 plotly.js JavaScript 그래프 라이브러리를 사용하여 대화 형 데이터 시각화를 렌더링합니다. Plotly.js는 약 35 개의 차트 유형을 지원하고 벡터 품질 SVG 및 고성능 WebGL로 차트를 렌더링합니다.

아래는 Pandas 데이터 프레임에서 산점도를 만드는 예입니다.

import dash
import dash_core_components as dcc
import dash_html_components as html
import pandas as pd
import plotly.graph_objs as go

app = dash.Dash()

df = pd.read_csv(
   'https://gist.githubusercontent.com/chriddyp/' +
   '5d1ea79569ed194d432e56108a04d188/raw/' +
   'a9f9e8076b837d541398e999dcbac2b2826a81f8/'+
   'gdp-life-exp-2007.csv')
	
app.layout = html.Div([
   dcc.Graph(
      id='life-exp-vs-gdp',
      figure={
         'data': [
            go.Scatter(
               x=df[df['continent'] == i]['gdp per capita'],
               y=df[df['continent'] == i]['life expectancy'],
               text=df[df['continent'] == i]['country'],
               mode='markers',
               opacity=0.7,
               marker={
                  'size': 15,
                  'line': {'width': 0.5, 'color': 'white'}
               },
               name=i
            ) for i in df.continent.unique()
         ],
         'layout': go.Layout(
            xaxis={'type': 'log', 'title': 'GDP Per Capita'},
            yaxis={'title': 'Life Expectancy'},
            margin={'l': 40, 'b': 40, 't': 10, 'r': 10},
            legend={'x': 0, 'y': 1},
            hovermode='closest'
         )
      }
   )
])

if __name__ == '__main__':
   app.run_server()

위 코드의 출력은 다음과 같습니다.

이러한 그래프는 대화 형이며 반응 형입니다. 포인트 위로 마우스를 가져가 해당 값을 확인하고, 범례 항목을 클릭하여 트레이스를 전환하고, 클릭하고 드래그하여 확대 / 축소하고, Shift 키를 누른 채 클릭하고 드래그하여 이동할 수 있습니다.

가격 인하

dash는 dash_html_components 라이브러리를 통해 HTML 맛을 노출하지만 HTML로 사본을 작성하는 것은 지루할 수 있습니다. 텍스트 블록을 작성하기 위해 dash_core_components 라이브러리의 Markdown 구성 요소를 사용할 수 있습니다.

핵심 구성 요소

dash_core_components에는 드롭 다운, 그래프, 마크 다운, 블록 등과 같은 상위 수준 구성 요소 집합이 포함됩니다.

다른 모든 Dash 구성 요소와 마찬가지로 완전히 선언적으로 설명됩니다. 구성 가능한 모든 옵션은 구성 요소의 키워드 인수로 사용할 수 있습니다.

다음은 사용 가능한 구성 요소 중 일부를 사용한 예입니다.

# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html

app = dash.Dash()

app.layout = html.Div([
   html.Label('Dropdown'),
   dcc.Dropdown(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      value='MTL'
   ),
	
   html.Label('Multi-Select Dropdown'),
   dcc.Dropdown(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      value=['MTL', 'SF'],
      multi=True
   ),
	
   html.Label('Radio Items'),
   dcc.RadioItems(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      value='MTL'
   ),
	
   html.Label('Checkboxes'),
   dcc.Checklist(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      values=['MTL', 'SF']
   ),

   html.Label('Text Input'),
   dcc.Input(value='MTL', type='text'),
	
   html.Label('Slider'),
   dcc.Slider(
      min=0,
      max=9,
      marks={i: 'Label {}'.format(i) if i == 1 else str(i) for i in range(1, 6)},
      value=5,
   ),
], style={'columnCount': 2})

if __name__ == '__main__':
   app.run_server(debug=True)

위 프로그램의 출력은 다음과 같습니다.

도움 요청

대시 구성 요소는 선언적입니다. 이러한 구성 요소의 모든 구성 가능한 측면은 설치 중에 키워드 인수로 설정됩니다. 모든 구성 요소의 Python 콘솔에서 도움말을 호출하여 구성 요소 및 사용 가능한 인수에 대해 자세히 알아볼 수 있습니다. 그들 중 일부는 아래에 주어진다-

>>> help(dcc.Dropdown)
Help on class Dropdown in module builtins:
class Dropdown(dash.development.base_component.Component)
| A Dropdown component.
| Dropdown is an interactive dropdown element for selecting one or more

| items.
| The values and labels of the dropdown items are specified in the `options`
| property and the selected item(s) are specified with the `value` property.
|
| Use a dropdown when you have many options (more than 5) or when you are
| constrained for space. Otherwise, you can use RadioItems or a Checklist,
| which have the benefit of showing the users all of the items at once.
|
| Keyword arguments:
| - id (string; optional)
| - options (list; optional): An array of options
| - value (string | list; optional): The value of the input. If `multi` is false (the default)
-- More --

요약하면 Dash 앱의 레이아웃은 앱의 모양을 설명합니다. 레이아웃은 구성 요소의 계층 구조 트리입니다. dash_html_components 라이브러리는 모든 HTML 태그 및 키워드 인수에 대한 클래스를 제공하고 style, className 및 id와 같은 HTML 속성을 설명합니다. dash_core_components 라이브러리는 컨트롤 및 그래프와 같은 상위 수준 구성 요소를 생성합니다.