डैश फ्रेमवर्क

इस अध्याय में, हम डैश फ्रेमवर्क के बारे में विस्तार से चर्चा करेंगे।

डैश एक ओपन-सोर्स पायथन फ्रेमवर्क है जिसका उपयोग विश्लेषणात्मक वेब अनुप्रयोगों के निर्माण के लिए किया जाता है। यह एक शक्तिशाली पुस्तकालय है जो डेटा-संचालित अनुप्रयोगों के विकास को सरल करता है। यह पायथन डेटा वैज्ञानिकों के लिए विशेष रूप से उपयोगी है जो वेब विकास से बहुत परिचित नहीं हैं। उपयोगकर्ता डैश का उपयोग करके अपने ब्राउज़र में अद्भुत डैशबोर्ड बना सकते हैं।

Plotly.js, React, और Flask के शीर्ष पर निर्मित, डैश आपके UI के ड्रापडाउन, स्लाइडर्स और ग्राफ़ जैसे आधुनिक UI तत्वों को सीधे आपके विश्लेषणात्मक अजगर कोड से जोड़ता है।

डैश ऐप्स में एक फ्लास्क सर्वर होता है जो HTTP अनुरोधों पर JSON पैकेट्स का उपयोग करके फ्रंट-एंड रिएक्ट घटकों के साथ संचार करता है।

डैश एप्लिकेशन को शुद्ध रूप से अजगर में लिखा गया है, इसलिए NO HTML या जावास्क्रिप्ट आवश्यक है।

डैश सेटअप

यदि डैश आपके टर्मिनल में पहले से स्थापित नहीं है, तो नीचे बताए गए डैश लाइब्रेरी को स्थापित करें। जैसा कि ये पुस्तकालय सक्रिय विकास के तहत हैं, स्थापित करें और अपग्रेड करें। अजगर 2 और 3 भी समर्थित हैं।

  • पाइप इंस्टॉल डैश == 0.23.1 # कोर डैश बैकएंड
  • पाइप इंस्टॉल डैश-रेंडरर == 0.13.0 # डैश फ्रंट-एंड
  • पाइप स्थापित डैश-एचटीएमएल-घटक == 0.11.0 # HTML घटक
  • पाइप स्थापित डैश-कोर-घटक == 0.26.0 # सुपरचार्ज किए गए घटक
  • पाइप स्थापित प्लॉटली == 3.1.0 # प्लॉटली लायब्रेरी

यह सुनिश्चित करने के लिए कि सब कुछ ठीक से काम कर रहा है, यहाँ, हमने एक साधारण डैशऐफ़डी फ़ाइल बनाई।

डैश या ऐप लेआउट

डैश ऐप दो भागों से बना होता है। पहला भाग ऐप का "लेआउट" है जो मूल रूप से बताता है कि आवेदन कैसा दिखता है। दूसरा भाग अनुप्रयोग की अन्तरक्रियाशीलता का वर्णन करता है।

प्रमुख घटक

हम के साथ लेआउट का निर्माण कर सकते हैं dash_html_components और यह dash_core_componentsपुस्तकालय। डैश अनुप्रयोग के सभी दृश्य घटकों के लिए अजगर कक्षाएं प्रदान करता है। हम जावास्क्रिप्ट और React.js के साथ अपने स्वयं के घटकों को भी अनुकूलित कर सकते हैं।

dcc के रूप में आयात dash_core_compenders

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.''')

और समतुल्य HTML कोड इस तरह दिखेगा -

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

सरल डैश एप्लिकेशन लेखन

हम सीखेंगे कि किसी फ़ाइल में उपर्युक्त लाइब्रेरी का उपयोग करके डैश पर एक सरल उदाहरण कैसे लिखें 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)

डैश ऐप चला रहा है

डैश ऐप चलाते समय निम्नलिखित बातों पर ध्यान दें।

(MyDjangoEnv) C: \ Users \ rajesh \ Desktop \ MyDjango \ डैश> python dashApp1.py

  • फ्लास्क ऐप "डैशऐप 1" सेवा (आलसी लोडिंग)

  • पर्यावरण: उत्पादन

    चेतावनी: उत्पादन वातावरण में विकास सर्वर का उपयोग न करें।

    इसके बजाय उत्पादन WSGI सर्वर का उपयोग करें।

  • डिबग मोड: पर

  • स्टैट के साथ फिर से शुरू करना

  • डीबगर सक्रिय है!

  • डीबगर पिन: 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 जैसे "घटकों" के एक पेड़ से बना है।

  • प्रत्येक HTML टैग के लिए डैश_एचटीएमएल_कंप्यूटर लाइब्रेरी का एक घटक है। HTML.H1 (बच्चों = 'हैलो डैश') घटक आपके आवेदन में एक <h1> हैलो डैश </ h1> HTML तत्व उत्पन्न करता है।

  • सभी घटक शुद्ध HTML नहीं हैं। डैश_कोर_कंप्यूटर उच्च-स्तरीय घटकों का वर्णन करते हैं जो इंटरएक्टिव होते हैं और रिएक्ट.एक्स लाइब्रेरी के माध्यम से जावास्क्रिप्ट, एचटीएमएल और सीएसएस के साथ उत्पन्न होते हैं।

  • प्रत्येक घटक को पूरी तरह से कीवर्ड विशेषताओं के माध्यम से वर्णित किया गया है। डैश घोषणात्मक है: आप मुख्य रूप से इन विशेषताओं के माध्यम से अपने आवेदन का वर्णन करेंगे।

  • बच्चों की संपत्ति विशेष है। सम्मेलन द्वारा, यह हमेशा पहली विशेषता है जिसका अर्थ है कि आप इसे छोड़ सकते हैं।

  • Html.H1 (बच्चों = 'हैलो डैश') html.H1 ('हैलो डैश') के समान है।

  • आपके एप्लिकेशन के फ़ॉन्ट यहां प्रदर्शित होने की तुलना में थोड़ा अलग दिखाई देंगे। यह एप्लिकेशन तत्वों की डिफ़ॉल्ट शैलियों को संशोधित करने के लिए एक कस्टम सीएसएस स्टाइलशीट का उपयोग कर रहा है। कस्टम फ़ॉन्ट शैली अनुमेय है, लेकिन अभी तक, हम नीचे दिए गए URL या अपनी पसंद के किसी भी URL को जोड़ सकते हैं -

    app.css.append_css ({"external_url":https://codepen.io/chriddyp/pen/bwLwgP.css}) इन उदाहरणों के समान रूप और अनुभव प्राप्त करने के लिए अपनी फ़ाइल प्राप्त करें।

HTML के बारे में अधिक

डैश_एचटीएमएल_कंप्यूटर लाइब्रेरी में प्रत्येक 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)

उपरोक्त उदाहरण में, हमने शैली संपत्ति के साथ html.Div और html.H1 घटकों की इनलाइन शैलियों को संशोधित किया है।

यह डैश एप्लिकेशन में निम्नानुसार प्रस्तुत किया गया है -

डैश_एचटीएमएल_काउंटर और एचटीएमएल विशेषताओं के बीच कुछ महत्वपूर्ण अंतर हैं -

  • डैश में शैली की संपत्ति के लिए, आप केवल एक शब्दकोश की आपूर्ति कर सकते हैं, जबकि HTML में, यह अर्धविराम से अलग स्ट्रिंग है।

  • शैली शब्दकोश कुंजी हैं camelCased, इसलिए पाठ-संरेखण में परिवर्तन होता है textalign

  • डैश में क्लासनेम HTML क्लास की विशेषता के समान है।

  • पहला तर्क HTML टैग के बच्चों का है जो बच्चों के कीवर्ड तर्क के माध्यम से निर्दिष्ट किया गया है।

पुन: प्रयोज्य अवयव

पायथन में अपने मार्कअप को लिखकर, हम संदर्भ या भाषा को बदले बिना तालिकाओं जैसे जटिल पुन: प्रयोज्य घटक बना सकते हैं -

नीचे एक त्वरित उदाहरण है जो पांडा डेटाफ्रेम से एक "तालिका" उत्पन्न करता है।

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)

हमारा आउटपुट कुछ इस तरह होगा -

विज़ुअलाइज़ेशन के बारे में अधिक

डैश_कोर_सॉफ़्टर्स लाइब्रेरी में एक घटक शामिल है जिसे कहा जाता है Graph

ग्राफ़ खुले स्रोत का उपयोग करके इंटरेक्टिव डेटा विज़ुअलाइज़ेशन को प्लॉट करता है। जावास्क्रिप्ट रेखांकन लाइब्रेरी। Plotly.js लगभग 35 चार्ट प्रकारों का समर्थन करता है और वेक्टर-गुणवत्ता वाले SVG और उच्च-प्रदर्शन वाले WebGL दोनों में चार्ट प्रस्तुत करता है।

नीचे एक उदाहरण दिया गया है जो पंडों के डेटाफ्रेम से एक स्कैटर प्लॉट बनाता है -

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()

उपरोक्त कोड का आउटपुट निम्नानुसार है -

ये रेखांकन संवादात्मक और उत्तरदायी हैं। आप उनके मूल्यों को देखने के लिए बिंदुओं पर होवर कर सकते हैं, लेज़र आइटम पर क्लिक करें निशान को टॉगल करने के लिए, क्लिक करें और ज़ूम करने के लिए खींचें, शिफ्ट को दबाए रखें, और क्लिक करें और पैन पर खींचें।

markdown

हालांकि डैश डैश_ html_compenders लाइब्रेरी के माध्यम से HTML फ्लेवर को उजागर करता है, यह HTML में आपकी कॉपी लिखने के लिए थकाऊ हो सकता है। ग्रंथों के ब्लॉक लिखने के लिए, आप डैश_कोर_सेंटर लाइब्रेरी में मार्कडाउन घटक का उपयोग कर सकते हैं।

प्रमुख घटक

डैश_कोर_कंप्यूटरों में उच्च-स्तरीय घटकों जैसे ड्रॉपडाउन, ग्राफ़, मार्कडाउन, ब्लॉक और कई और अधिक शामिल हैं।

अन्य सभी डैश घटकों की तरह, उन्हें पूरी तरह से घोषित रूप से वर्णित किया गया है। हर विकल्प जो विन्यास योग्य है वह घटक के एक कीवर्ड तर्क के रूप में उपलब्ध है।

नीचे दिए गए कुछ घटकों का उपयोग करके उदाहरण दिया गया है -

# -*- 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)

उपरोक्त कार्यक्रम से आउटपुट निम्नानुसार है -

कॉलिंग हेल्प

डैश घटक घोषणात्मक हैं। इन घटकों का प्रत्येक विन्यासनीय पहलू इंस्टालेशन के दौरान एक कीवर्ड तर्क के रूप में सेट किया जाता है। आप किसी घटक के बारे में और उसके उपलब्ध तर्कों के बारे में अधिक जानने के लिए किसी भी घटक पर अपने अजगर कंसोल में मदद कर सकते हैं। उनमें से कुछ नीचे दिए गए हैं -

>>> 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 --

संक्षेप में, डैश ऐप का लेआउट बताता है कि ऐप कैसा दिखता है। लेआउट घटकों का एक श्रेणीबद्ध पेड़ है। डैश_एचटीएमएल_कंप्यूटर लाइब्रेरी सभी एचटीएमएल टैग और कीवर्ड तर्क के लिए कक्षाएं प्रदान करता है, और शैली, क्लासनेम और आईडी जैसी HTML विशेषताओं का वर्णन करता है। डैश_कोर_कंप्यूटर लाइब्रेरी नियंत्रण और ग्राफ़ जैसे उच्च-स्तरीय घटक उत्पन्न करती है।