Python使用Dash开发网页应用的方法详解

作者:魔法小木瓜 时间:2022-04-26 03:45:14 

Python Dash开发Web应用的控件基础

本文主要是通过Dash的Checklist组件,简单介绍使用Dash开发的Web应用

展示效果如下:

Python使用Dash开发网页应用的方法详解

python dash简单基础

Dash应用程序由两部分组成:

  • 第一部分是应用程序的布局(Layout),它描述了应用程序的外观。

  • 第二部分描述了应用程序的交互性。

一、Dash的布局Layout

Dash应用的布局描述了应用的外观。布局是一个分层的组件树。

Dash HTML Components(dash.html)为所有HTML tags和HTML属性关键字参数描述提供类,如style, class和id。

Dash核心组件(dash .dcc)生成高级组件,如控件和图形。

Dash Layout有几个特点:

  • 布局由组件树组成。

  • 可创建复杂的可复用的组件。

  • 核心组件模块dash .dcc包含一个名为Graph的组件,Graph使用开源的plotly.js JavaScript图形库呈现交互式数据可视化。js支持超过35种图表类型,并以矢量质量的SVG和高性能的WebGL呈现图表,详细可参考: plotly.py documentation and gallery。

  • 对于编写文本块,可以使用dash.dcc中的Markdown组件。

  • Dash核心组件(dash .dcc)包括一组较高级的组件,如下拉菜单、图形、标记块等。

1、Dash的HTML组件

Dash是一个web应用程序框架,它提供了围绕HTML、CSS和JavaScript的纯Python抽象。而不是编写HTML或使用HTML模板引擎,用Python和Dash HTML Components模块组成布局。

Dash HTML组件模块是Dash的一部分,可以在https://github.com/plotly/dash找到它的源代码。

2、Dash的Core组件

Dash配备了用于交互用户界面的动态组件。

Dash核心组件模块可以被导入和使用,通过 from dash import dcc 并允许访问许多交互式组件,包括下拉菜单、检查列表和滑块。

dcc模块是Dash的一部分,可以在https://github.com/plotly/dash找到它的源代码。

二、Dash Core中的Checklist

dcc.Checklist是一个用于呈现一组复选框的组件。

下面我们借助Checklist控件,组建一个简单工程,以说明Dash开发Web应用的一些简单内容

Demo的目录结构如下:

.
└── dash_demo
   ├── app.py
   └── assets
       ├── favicon.ico
       └── img
           ├── julia_50px_icon.png
           ├── python_50px_icon.png
           └── r_50px_icon.png

app.py的内容如下:

from dash import Dash, html, dcc
app = Dash(__name__)
app.title = 'Dash控件教程'
app.layout = html.Div(children=[
   dcc.Checklist(
       options=['Python语言', 'Julia语言', 'R语言'],
       value=['Python语言', 'R语言']
   ),
   dcc.Checklist(
       options=[
           {'label': 'Python语言', 'value': '1'},
           {'label': 'Julia语言', 'value': '2'},
           {'label': 'R语言', 'value': '3'},
       ],
       value=['1', '3']
   ),
   dcc.Checklist(
       options={
           '1': 'Python语言',
           '2': 'Julia语言',
           '3': 'R语言',
       },
       value=['1', '3']
   ),
   dcc.Checklist(
       options=[
           {
               'label': html.Img(src=app.get_asset_url('img/python_50px_icon.png')),
               'value': 'Python语言',
           },
           {
               'label': html.Img(src=app.get_asset_url('img/julia_50px_icon.png')),
               'value': 'Julia语言',
           },
           {
               'label': html.Img(src=app.get_asset_url('img/r_50px_icon.png')),
               'value': 'R语言',
           },
       ],
       value=['Python语言', 'R语言']
   ),
])

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

运行工程:python app.py。

浏览器访问:http://127.0.0.1:8050。

Python使用Dash开发网页应用的方法详解

Dash Demo

简单说明:

  • assets目录,是官方推荐的用于存放我们的 Dash 应用所依赖静态资源文件的目录,如依赖的 css 、 js 、 favicon.ico 、各种图片及字体等静态资源。

  • Dash控件有多种使用形式,很灵活,例如文中的Checklist,选项的标签(用户看到的)和值(传递给回调的)是等价的。使用时,我们更倾向于将它们分开,这样就可以很容易地更改标签,而不更改使用该值的回调逻辑。

来源:https://www.51cto.com/article/719123.html

标签:Python,Dash,网页,应用
0
投稿

猜你喜欢

  • python Gunicorn服务器使用方法详解

    2021-09-06 00:35:08
  • MySQL更新删除操作update和delete使用详解(小白慎用)

    2024-01-13 14:03:30
  • Python中parsel两种获取数据方式小结

    2023-03-01 17:44:50
  • Python爬取网易云音乐上评论火爆的歌曲

    2021-09-16 11:49:53
  • 一个不错的javascript加密解密算法源码

    2010-03-28 13:12:00
  • Python中logging日志的四个等级和使用

    2023-05-10 14:57:41
  • python多线程调用exit无法退出的解决方法

    2023-04-19 19:41:48
  • python实现scrapy爬虫每天定时抓取数据的示例代码

    2022-05-04 22:33:18
  • Alfred + Gitee搭建免费图床的使用实例详解

    2023-10-04 08:24:30
  • Windows安装Anaconda3的方法及使用过程详解

    2022-03-03 06:20:10
  • python实现处理Excel表格超详细系列

    2021-06-22 13:34:36
  • ACCESS入门教程:窗口和菜单的使用

    2008-01-03 20:15:00
  • php+js实现倒计时功能

    2023-11-12 17:16:29
  • Python随机生成8位密码的示例详解

    2023-09-15 21:04:03
  • 微信小程序开发常用功能汇总

    2024-02-27 05:23:56
  • MySQL数据库入门之备份数据库操作详解

    2024-01-24 07:10:05
  • Python迭代器iterator生成器generator使用解析

    2023-11-17 18:50:24
  • Oracle 中文字段进行排序的sql语句

    2009-09-26 18:58:00
  • mysql中如何查询数据库中的表名

    2024-01-20 03:07:32
  • python 网络编程要点总结

    2023-09-30 06:15:38
  • asp之家 网络编程 m.aspxhome.com