8288分类目录 8288分类目录 8288分类目录
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

使用Django Highcharts制作图表

来源:本站原创 浏览:77次 时间:2022-08-30

在运维工作总很多数据最终的展现方式要用到图表,毕竟用图来展示要比一堆数字更直观些,比如利用率、站点的PV,UV等,大家千万不要觉得看到很多漂亮的图就感觉很难,其实真心不是,因为现在有很多前端的绘图库,你只需要按它要求的格式(json)提供给前端接口,什么曲线图、饼图,还有你从来都不知道的图都可以生成出来,现在用的比较多的是highcharts,echarts等,django-highcharts是django的一个集成库,使用它在django里更方便绘制出我们想要的图表,所以这篇文章就使用它来完成一个超小项目,实现一个站点的PV,UV曲线图, 另外我一直认为公众号其实不太合适贴太多的代码,要看代码最好还是用专业的编辑器,如果通篇都是代码,我估计很多人直接就收藏了,时间久了自己都忘了,起不到真正学习的目的, 所以今天我重点还是讲使用步骤,确保下次大家开发的时候会用,代码只是辅助,当然核心的我也会全部贴出来,但完整的代码限于篇幅就不在贴了,另外这篇是需要小伙伴们有django一点点基础的,如果没有任何基础,可能需要先了解下基本mvc的概念,否则你可能会看的云里雾里, 其它不多说了,现在开始,我先介绍下开发环境:


python 2.7 + django1.8.2 + mysql (版本随意)

第一步,安装django-highcharts,这个根据大家使用的环境即可,pip或直接用pycharm工具安装都可以。

第二步,新建project 和app

第三步,以上做完,就可以敲代码了,先建models,就是数据库表的表结构,日常站点访问数据PV,UV数据可以插入到这个表里,一会我们要使用。

第四步,图表模块代码编写,这部分主要是一个类从数据库表中获取数据,然后将数据提供给图形展示类,代码如下:

class pudata(object):


    def __init__(self, dbobj):

        self.dbobj = dbobj

        self.pdays = self.dbobj.objects.all()


    def mpvdate(self):

        res = {}

        for v in self.pdays:

            res[v.days] = v.pvisitor

        res = collections.OrderedDict(sorted(res.items(), key=lambda d: d[0]))

        return res


    def muvdate(self):

        res = {}

        for v in self.pdays:

            res[v.days] = v.uvisitor

        res = collections.OrderedDict(sorted(res.items(), key=lambda d: d[0]))

        return res


class MindgViewPv(HighChartsMultiAxesView):

    p = pudata(mindg)

    title = 'mindg.cn'

    tooltip = {'shared': 'true'}

    chart_type = 'spline'

    categories = p.mpvdate().keys()


    @property

    def yaxis(self):

        y_axis = [

        {

            'title': {

                'text': 'PV'

            },

        }

        ]

        return y_axis


    @property

    def series(self):

        p = pudata(mindg)

        series = [

            {

            'name': 'mindg.cn',

            'data': p.icypvdate().values()

            }]

        return series

第五步,模板层代码,模板采用ajax方式,从后台获取的json数据给highcharts然后绘制曲线图,代码如下:

{% extends 'head_css.html' %}

{% load highcharts_tags %}


{% block js %}

  <script type="text/javascript">

    $(function (){

        $.getJSON("{% url 'mpv' %}", function(data) {

            $('#container').highcharts(data);

        });

    });

    </script>

 {% endblock %}

有了上面的代码,就可以通过view函数将mindg.html 渲染出来了,最终图如下:


  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net