dash--项目的前端展示简单基础

1.前置工作

创建虚拟环境:

复制代码
sudo apt-get install python3-venv # 安装
python3 -m venv venv # 在本目录下创建venv虚拟环境(也是一个文件夹。如果用不到这个虚拟环境以后就rm -rf venv)
source venv/bin/activate # 激活虚拟环境

临时使用清华大学的镜像源安装 Python 包:

复制代码
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple 包名

永久更改 pip 的默认源:

复制代码
pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple

2.示例

创建一个基本的 Dash 应用程序的入口文件 app.py,并在其中添加一个简单的布局和回调:

复制代码
import dash
import dash_html_components as html
import dash_core_components as dcc
from dash.dependencies import Input, Output

# 创建 Dash 应用程序
app = dash.Dash(__name__)

# 布局
app.layout = html.Div([
    html.H1("Welcome to My Dashboard"),
    dcc.Input(id='input', value='initial text', type='text'),
    html.Div(id='output')
])

# 回调函数
@app.callback(
    Output('output', 'children'),
    [Input('input', 'value')]
)
def update_output(value):
    return f'You entered: {value}'

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

运行python app.py,然后在浏览器中访问 http://127.0.0.1:8050/

在这个示例中,我们创建了一个带有一个输入框和一个文本输出的简单布局。然后,我们定义了一个回调函数,该函数接收输入框的值,并将其显示在文本输出中。

可以使用 Dash 的核心组件和 HTML 组件来创建各种不同类型的图表、表格和交互元素,并使用回调函数来处理用户输入并更新显示。

3. 分离app.pycallbacks.pylayout.py

app.py

复制代码
import dash
from layout import layout


# 导入外部CSS文件
external_stylesheets = ['https://codepen.io/dilums/pen/ZEBowxX.css']

# 创建Dash应用并加载外部样式表
app = dash.Dash(__name__, external_stylesheets=external_stylesheets)

from callbacks import *

# 设置应用的布局
app.layout = layout

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

callbacks.py

复制代码
from dash.dependencies import Input, Output
from app import app

# 示例回调函数,将输入文本框的内容显示在输出Div中
@app.callback(
    Output('my-output', 'children'),
    [Input('my-input', 'value')]
)
def update_output(value):
    return f'输入的内容是: {value}'

# 如果有多个回调函数,可以在此继续添加

layout.py

复制代码
from dash import html
from dash import dcc

layout = html.Div([html.H1("简单的Dash应用"),
    
    # 一个简单的文本框
    dcc.Input(id='my-input', value='', type='text'),
    
    # 一个显示文本的空间
    html.Div(id='my-output')
])

分离三个文件,让这个项目更方便重构。

4.使用 pip freeze 命令来生成当前虚拟环境中已安装的包的列表

复制代码
`pip freeze > requirements.txt`
相关推荐
一枚前端小能手18 小时前
🔐 单点登录还在手动跳转?这几个SSO实现技巧让你的用户体验飞起来
前端·javascript
小潘同学18 小时前
Vue3中响应式数据深度拷贝 Avoid app logic that relies on,,,,,,,,
前端
六六Leon18 小时前
Kuikly跨端模式接入资源管理
前端
流浪大叔18 小时前
Python下载实战技巧的技术文章大纲
开发语言·python
tianchang18 小时前
深入理解 JavaScript 异步机制:从语言语义到事件循环的全景图
前端·javascript
旺仔牛仔QQ糖18 小时前
Vue3.0 Hook 使用好用多多
前端
用户685453759776918 小时前
🎯 Python迭代器与生成器:从入门到"哦原来如此!"
python
开心-开心急了18 小时前
PySide6 使用搜索引擎搜索 多类实现 更新1次
python·pyqt·pyside
万粉变现经纪人18 小时前
如何解决 pip install -r requirements.txt 子目录可编辑安装缺少 pyproject.toml 问题
开发语言·python·scrapy·beautifulsoup·scikit-learn·matplotlib·pip
~无忧花开~18 小时前
CSS学习笔记(五):CSS媒体查询入门指南
开发语言·前端·css·学习·媒体