Kerangka Dash

Pada bab ini, kita akan membahas tentang kerangka Dash secara detail.

Dash adalah framework Python open-source yang digunakan untuk membangun aplikasi web analitik. Ini adalah pustaka yang kuat yang menyederhanakan pengembangan aplikasi berbasis data. Ini sangat berguna untuk ilmuwan data Python yang tidak terlalu paham dengan pengembangan web. Pengguna dapat membuat dasbor luar biasa di browser mereka menggunakan dasbor.

Dibangun di atas Plotly.js, React, dan Flask, Dash mengikat elemen UI modern seperti dropdown, slider dan grafik langsung ke kode python analitis Anda.

Aplikasi Dash terdiri dari server Flask yang berkomunikasi dengan komponen React front-end menggunakan paket JSON melalui permintaan HTTP.

Aplikasi dasbor ditulis murni dengan python, jadi TIDAK diperlukan HTML atau JavaScript.

Pengaturan Dash

Jika Dash belum diinstal di terminal Anda, instal pustaka Dash yang disebutkan di bawah ini. Karena pustaka ini sedang dalam pengembangan aktif, instal dan perbarui kemudian sesering mungkin. Python 2 dan 3 juga didukung.

  • pip install dash == 0.23.1 # Backend dasbor inti
  • pip install dash-renderer == 0.13.0 # Dash front-end
  • pip install dash-html-components == 0.11.0 # komponen HTML
  • pip install dash-core-components == 0.26.0 # Komponen supercharged
  • pip install plotly == 3.1.0 # Perpustakaan grafik secara plot

Untuk memastikan semuanya bekerja dengan baik, di sini, kami membuat file dashApp.py sederhana.

Dash atau App Layout

Aplikasi Dash terdiri dari dua bagian. Bagian pertama adalah “tata letak” aplikasi yang pada dasarnya menjelaskan bagaimana tampilan aplikasi. Bagian kedua menjelaskan interaktivitas aplikasi.

Komponen Inti

Kita bisa membangun tata letak dengan dash_html_components dan dash_core_componentsPerpustakaan. Dash menyediakan kelas python untuk semua komponen visual aplikasi. Kami juga dapat menyesuaikan komponen kami sendiri dengan JavaScript dan React.js.

impor dash_core_components sebagai dcc

impor dash_html_components sebagai html

Dash_html_components adalah untuk semua tag HTML di mana dash_core_components adalah untuk interaktivitas yang dibangun dengan React.js.

Menggunakan dua perpustakaan di atas, mari kita tulis kode seperti yang diberikan di bawah ini -

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

Dan kode HTML yang setara akan terlihat seperti ini -

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

Menulis aplikasi Dash Sederhana

Kita akan belajar bagaimana menulis contoh sederhana di dasbor menggunakan pustaka yang disebutkan di atas dalam sebuah file 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)

Menjalankan aplikasi Dash

Perhatikan poin-poin berikut saat menjalankan aplikasi Dash.

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

  • Melayani aplikasi Flask "dashApp1" (pemuatan lambat)

  • Lingkungan: produksi

    PERINGATAN: Jangan gunakan server pengembangan di lingkungan produksi.

    Gunakan server produksi WSGI sebagai gantinya.

  • Mode debug: aktif

  • Memulai kembali dengan stat

  • Debugger aktif!

  • PIN Debugger: 130-303-947

  • Berlari http://127.0.0.1:8050/ (Tekan CTRL + C untuk keluar)

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 -

Mengunjungi http:127.0.0.1:8050/di browser web Anda. Anda akan melihat aplikasi yang terlihat seperti ini.

Dalam program di atas, beberapa poin penting yang perlu diperhatikan adalah sebagai berikut -

  • Tata letak aplikasi terdiri dari pohon "komponen" seperti html.Div dan dcc.Graph.

  • Pustaka dash_html_components memiliki komponen untuk setiap tag HTML. Komponen html.H1 (children = 'Hello Dash') menghasilkan elemen HTML <h1> Hello Dash </h1> dalam aplikasi Anda.

  • Tidak semua komponen adalah HTML murni. Dash_core_components mendeskripsikan komponen tingkat yang lebih tinggi yang interaktif dan dibuat dengan JavaScript, HTML, dan CSS melalui perpustakaan React.js.

  • Setiap komponen dijelaskan seluruhnya melalui atribut kata kunci. Dash bersifat deklaratif: Anda terutama akan mendeskripsikan aplikasi Anda melalui atribut ini.

  • Properti anak-anak itu istimewa. Secara konvensi, itu selalu atribut pertama yang berarti Anda bisa menghilangkannya.

  • Html.H1 (children = 'Hello Dash') sama dengan html.H1 ('Hello Dash').

  • Font di aplikasi Anda akan terlihat sedikit berbeda dari yang ditampilkan di sini. Aplikasi ini menggunakan lembar gaya CSS khusus untuk mengubah gaya default elemen. Gaya font khusus diperbolehkan, tetapi mulai sekarang, kami dapat menambahkan URL di bawah ini atau URL pilihan Anda -

    app.css.append_css ({“external_url”:https://codepen.io/chriddyp/pen/bwLwgP.css}) agar file Anda mendapatkan tampilan dan nuansa yang sama dari contoh ini.

Lebih lanjut tentang HTML

Pustaka dash_html_components berisi kelas komponen untuk setiap tag HTML serta argumen kata kunci untuk semua argumen HTML.

Mari kita tambahkan gaya sebaris komponen dalam teks aplikasi kita sebelumnya -

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

Dalam contoh di atas, kami memodifikasi gaya sebaris dari komponen html.Div dan html.H1 dengan properti gaya.

Itu dirender di aplikasi Dash sebagai berikut -

Ada beberapa perbedaan utama antara dash_html_components dan atribut HTML -

  • Untuk properti gaya di Dash, Anda cukup menyediakan kamus, sedangkan di HTML, itu adalah string yang dipisahkan titik koma.

  • Tombol kamus gaya adalah camelCased, jadi text-align berubah menjadi textalign.

  • ClassName di Dash mirip dengan atribut kelas HTML.

  • Argumen pertama adalah turunan dari tag HTML yang ditentukan melalui argumen kata kunci turunan.

Komponen yang Dapat Digunakan Kembali

Dengan menulis markup kita dengan Python, kita dapat membuat komponen kompleks yang dapat digunakan kembali seperti tabel tanpa mengganti konteks atau bahasa -

Di bawah ini adalah contoh cepat yang menghasilkan "Tabel" dari pandas dataframe.

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)

Output kami akan menjadi seperti -

Lebih lanjut tentang Visualisasi

Pustaka dash_core_components menyertakan sebuah komponen bernama Graph.

Grafik menampilkan visualisasi data interaktif menggunakan pustaka grafik JavaScript plotly.js sumber terbuka. Plotly.js mendukung sekitar 35 jenis bagan dan menampilkan bagan dalam SVG kualitas vektor dan WebGL berkinerja tinggi.

Di bawah ini adalah contoh yang membuat plot sebar dari bingkai data 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()

Output dari kode diatas adalah sebagai berikut -

Grafik ini interaktif dan responsif. Anda dapat mengarahkan kursor ke titik untuk melihat nilainya, klik item legenda untuk beralih jejak, klik dan seret untuk memperbesar, tahan shift, dan klik dan seret untuk menggeser.

Penurunan harga

Meskipun tanda hubung memperlihatkan citarasa HTML melalui pustaka dash_html_components, menulis salinan Anda dalam HTML dapat menjadi pekerjaan yang membosankan. Untuk menulis blok teks, Anda dapat menggunakan komponen penurunan harga di pustaka dash_core_components.

Komponen Inti

Dash_core_components menyertakan sekumpulan komponen dengan level yang lebih tinggi seperti dropdown, grafik, penurunan harga, blok, dan banyak lagi.

Seperti semua komponen Dash lainnya, mereka dijelaskan seluruhnya secara deklaratif. Setiap opsi yang dapat dikonfigurasi tersedia sebagai argumen kata kunci dari komponen tersebut.

Di bawah ini adalah contohnya, menggunakan beberapa komponen yang tersedia -

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

Output dari program di atas adalah sebagai berikut -

Memanggil Bantuan

Komponen dasbor bersifat deklaratif. Setiap aspek yang dapat dikonfigurasi dari komponen ini ditetapkan selama instalasi sebagai argumen kata kunci. Anda dapat memanggil bantuan di konsol python Anda pada salah satu komponen untuk mempelajari lebih lanjut tentang komponen dan argumen yang tersedia. Beberapa dari mereka diberikan di bawah ini -

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

Untuk meringkas, tata letak aplikasi Dash mendeskripsikan seperti apa aplikasi itu. Tata letak adalah pohon hierarki komponen. Pustaka dash_html_components menyediakan kelas untuk semua tag HTML dan argumen kata kunci, dan menjelaskan atribut HTML seperti style, className, dan id. Pustaka dash_core_components menghasilkan komponen tingkat yang lebih tinggi seperti kontrol dan grafik.