您现在的位置是:网站首页> 编程资料编程资料
Django与图表的数据交互的实现_python_
2023-05-26
309人已围观
简介 Django与图表的数据交互的实现_python_
在Django开发过程中,遇到了需要图表进行数据可视化的需要。因此查询了相关文档,并记录下如何实现与图表的数据交互。 本人是个前端小白,只会改不会写(套模板)。
仅供参考!!!
环境相关
Django (版本不限,当然不同的版本有不同的后端代码写法。本文环境为Django 3.1)
echarts (前端的画图框架,导入JS包即可) 点击网址可以找到模板 网址
JQuery (用于Ajax请求 导入JS包即可 在文中会有JS包地址)
实现思路(需要理解的请结合代码来看)
- 后端方面主要涉及到了ajax,其实就是前端对后端请求一个特定的地址,后端收到请求后,将数据整理并打包成json格式向前端发送,有点类似于在写API接口。
- 前端方面。主要有两个点:echarts 和Ajax 。
- echarts 中可以看到,生成的模板里面有2个data项,用于储存数据信息制作表格。 (不同的图表有不同的数据点,本文只有2个data项,生成折线图)
- Ajax 用于向后端发送请求。
- 在编写过程中,先将echarts 表的数据项清空(data : [])。 后续通过ajax请求向后端请求数据包,并提取对应的数据加入到echarts 表的数据项中。
代码:
urls.py
re_path('ajax_line/', views.ajax_line, name='ajax_line'),ajax请求接口:
from django.db import models from datetime import datetime # Create your models here. class Shop(models.Model): Name = models.CharField(max_length=50, verbose_name='名称') Barcode = models.CharField(max_length=50, verbose_name='条形码' ,default ='') Money = models.IntegerField(default=0, verbose_name='单价') number = models.IntegerField(default=0, verbose_name='库存') Other = models.CharField(max_length=100, verbose_name='备注' ,default='无') objects = models.Manager() def __str__(self): return self.Name class Meta: verbose_name = '商品' verbose_name_plural = verbose_name class ShopOrders(models.Model): Produce = models.ManyToManyField(Shop, verbose_name='产品清单', blank=True) Money = models.IntegerField(default=0, verbose_name='合计') add_time = models.DateTimeField(default=datetime.now, verbose_name='时间') Other = models.CharField(max_length=100, verbose_name='备注' , default='无') Owner = models.CharField(max_length=50, verbose_name='销售人员',default ='') FRESHMAN = 'FR' SOPHOMORE = 'SO' JUNIOR = 'JR' YEAR_IN_SCHOOL_CHOICES = ( (FRESHMAN, '微信'), (SOPHOMORE, '现金'), (JUNIOR, '支付宝'), ) Type = models.CharField( max_length=2, choices=YEAR_IN_SCHOOL_CHOICES, default=FRESHMAN, ) objects = models.Manager() def __str__(self): return self.Owner class Meta: verbose_name = '商品订单' verbose_name_plural = verbose_name
models
from django.db import models from datetime import datetime # Create your models here. class Shop(models.Model): Name = models.CharField(max_length=50, verbose_name='名称') Barcode = models.CharField(max_length=50, verbose_name='条形码' ,default ='') Money = models.IntegerField(default=0, verbose_name='单价') number = models.IntegerField(default=0, verbose_name='库存') Other = models.CharField(max_length=100, verbose_name='备注' ,default='无') objects = models.Manager() def __str__(self): return self.Name class Meta: verbose_name = '商品' verbose_name_plural = verbose_name class ShopOrders(models.Model): Produce = models.ManyToManyField(Shop, verbose_name='产品清单', blank=True) Money = models.IntegerField(default=0, verbose_name='合计') add_time = models.DateTimeField(default=datetime.now, verbose_name='时间') Other = models.CharField(max_length=100, verbose_name='备注' , default='无') Owner = models.CharField(max_length=50, verbose_name='销售人员',default ='') FRESHMAN = 'FR' SOPHOMORE = 'SO' JUNIOR = 'JR' YEAR_IN_SCHOOL_CHOICES = ( (FRESHMAN, '微信'), (SOPHOMORE, '现金'), (JUNIOR, '支付宝'), ) Type = models.CharField( max_length=2, choices=YEAR_IN_SCHOOL_CHOICES, default=FRESHMAN, ) objects = models.Manager() def __str__(self): return self.Owner class Meta: verbose_name = '商品订单' verbose_name_plural = verbose_name
前端
月度销售情况
>
成果展示

参考博客
到此这篇关于Django与图表的数据交互的实现的文章就介绍到这了,更多相关Django 图表数据交互内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
您可能感兴趣的文章:
相关内容
- echarts动态获取Django数据的实现示例_python_
- Python实现一键抠图的示例代码_python_
- Python利用Bokeh进行数据可视化的教程分享_python_
- Python pygame绘制游戏图像_python_
- Python+Scipy实现自定义任意的概率分布_python_
- Django数据映射(一对一,一对多,多对多)_python_
- python标准库学习之sys模块详解_python_
- Python实现打印彩色字符串的方法详解_python_
- Ubuntu Server 20.04 LTS 环境下搭建vim 编辑器Python IDE的详细步骤_python_
- python中内置库os与sys模块的详细介绍_python_
