Django與圖表的數據交互的實現
在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
前端
<!-- THIS EXAMPLE WAS DOWNLOADED FROM https://echarts.apache.org/examples/zh/editor.html?c=line-simple --> <!DOCTYPE html> <html lang="zh-CN" style="height: 100%"> <head> <meta charset="utf-8"> </head> <body style="height: 100%; margin: 0"> <h1 style="Text-align:center"> 月度銷售情況</h1>> <div id="container" style="height: 100%"></div> <script type="text/javascript" src="https://fastly.jsdelivr.net/npm/[email protected]/dist/echarts.min.js"></script> <script type="text/javascript" charset="utf8" src="http://code.jquery.com/jquery-1.10.2.min.js"></script> <script type="text/javascript"> var dom = document.getElementById('container'); var myChart = echarts.init(dom, null, { renderer: 'canvas', useDirtyRect: false }); var app = {}; var option; option = { xAxis: { type: 'category', data: [] }, yAxis: { type: 'value' }, series: [ { data: [], type: 'line' } ] }; if (option && typeof option === 'object') { myChart.setOption(option); } window.addEventListener('resize', myChart.resize); myChart.showLoading(); var names = []; var brower = []; $.ajax({ // ajax的方式動態獲取後端代碼 type: 'get', url: '/index/ajax_line/', dataType: 'json', success: function (result) { $.each(result.data, function (index, item) { names.push(item.name); brower.push({ value: item.count, name: item.name }); }); myChart.hideLoading(); myChart.setOption({ xAxis: { data: names }, series: [{ data: brower }] }); }, error: function (errormsg) { alert('errormsg'); myChart.hideLoading(); } }); </script> </body> </html>
成果展示
參考博客
echarts動態獲取Django數據
到此這篇關於Django與圖表的數據交互的實現的文章就介紹到這瞭,更多相關Django 圖表數據交互內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Python Django模型詳解
- Django使用echarts進行可視化展示的實踐
- Django利用AJAX技術實現博文實時搜索
- echarts動態獲取Django數據的實現示例
- Django表單外鍵選項初始化的問題及解決方法