岗位分析与可视化系统(三)

本文档详细介绍了如何构建数据分析的可视化系统,包括薪资、企业、福利、学历分布、企业融资和城市类型的分析页面。每个页面的实现涉及到在views中编写分析代码,将具体逻辑封装在utils模块中,并在templates目录下创建对应的HTML页面展示数据。
摘要由CSDN通过智能技术生成

五、可视化

5.1薪资页面

在views,编写薪资分析的代码

def salary(request):
    uname = request.session['username']
    userInfo = User.objects.get(username=uname)
    edus, workexps = getSalary.getPageDt()
    defaultedu = '不限'
    defaultworkexp = '不限'
    if request.GET.get('edu'):
        defaultedu = request.GET.get('edu')
    if request.GET.get('workexp'):
        defaultworkexp = request.GET.get('workexp')
    salarylist, barData, legends = getSalary.getBar(defaultedu, defaultworkexp)
    pieData = getSalary.pieData()
    loudou = getSalary.getLouDou()
    return render(request, 'salaryChart.html', {
        'userInfo': userInfo,
        'edus': edus,
        'workexps': workexps,
        'defaultedu': defaultedu,
        'defaultworkexp': defaultworkexp,
        'salarylist': salarylist,
        'barData': barData,
        'legends': legends,
        'pieData': pieData,
        'loudou': loudou
    })

对个薪资分析,写在/myapp/utils中的getSalary.py中,在views调用函数方法

from .getPublicData import *
from myapp.models import JobInfo
import json
def getPageDt():
    return list(edus.keys()), workexp


def getBar(defaultedu, defaultworkexp):
    if defaultedu == '不限' or defaultworkexp == '不限':
        jobs = JobInfo.objects.all()
    elif defaultworkexp == '不限':
        jobs = JobInfo.objects.filter(edu=defaultedu)
    elif defaultedu == '不限':
        jobs = JobInfo.objects.filter(workexp=defaultworkexp)
    else:
        jobs = JobInfo.objects.filter(edu=defaultedu, workexp=defaultworkexp)
    jobType = {}
    for j in jobs:
        if j.pratice == '0':
            if jobType.get(j.type, -1) == -1:
                jobType[j.type] = [json.loads(j.salary)[1]]
            else:
                jobType[j.type].append(json.loads(j.salary)[1])
    barData = {}
    for k, v in jobType.items():
        if not barData.get(k, 0):
            barData[k] = [0 for x in range(5)]
        for i in v:
            s = i / 1000
            if s < 10:
                barData[k][0] += 1
            elif s >= 10 and s < 20:
                barData[k][1] += 1
            elif s >= 20 and s < 30:
                barData[k][2] += 1
            elif s >= 30 and s < 40:
                barData[k][3] += 1
            else:
                barData[k][4] += 1
  
    legends = list(barData.keys())
 
    if len(legends) == 0:
        legends = None
    return salarylist, barData, legends


def average(list):
    total = 0
    for i in list:
        total += i
    return round(total / len(list), 2)


def pieData():
    job = getAllJobs()
    jobType = {}
    for j in job:
        if j.pratice == '1':
            if jobType.get(j.type, -1) == -1:
                jobType[j.type] = [json.loads(j.salary)[1]]
            else:
                jobType[j.type].append(json.loads(j.salary)[1])
   
    result = []
    for k, v in jobType.items():
        result.append({
            'name': k,
            'value': average(v)
        })
   
    return result


def getLouDou():
    job = JobInfo.objects.filter(salaryMonth__gt=0)
    data = {}
    for i in job:
        x = str(i.salaryMonth) + '薪'
        if data.get(x, -1) == -1:
            data[x] = 1
        else:
            data[x] += 1
    result = []
    for k, v in data.items():
        result.append({
            'name': k,
            'value': v
        })
    return result

在/myapp/templates/下新建salaryChart.html页面,编写网页代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta name="description" content="Neon Admin Panel">
    <meta name="author" content="">
    <title>
        薪资
    </title>
    <link rel="stylesheet" href="/static/css/jquery-ui-1.10.3.custom.min.css">
    <link rel="stylesheet" href="/static/css/entypo.css">
    <link rel="stylesheet" href="/static/css/css.css">
    <link rel="stylesheet" href="/static/css/bootstrap.css">
    <link rel="stylesheet" href="/static/css/neon-core.css">
    <link rel="stylesheet" href="/static/css/neon-theme.css">
    <link rel="stylesheet" href="/static/css/neon-forms.css">
    <link rel="stylesheet" href="/static/css/custom.css">
    <script src="/static/js/jquery-1.11.0.min.js"></script>
    <script src="/assets/js/ie8-responsive-file-warning.js"></script>
    <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
    <script src="https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js"></script>
</head>
<body class="page-body  page-left-in" data-url="http://neon.dev">
<div class="page-container">
    <div class="sidebar-menu">
        <header class="logo-env">
            <div class="logo">
                <a href="index.html">
                    <h3 style="color: #fff1f0;font-weight: bold;margin-top: 5px">岗位数据可视化</h3>
                </a>
            </div>
        </header>
        <div class="sidebar-user-info">
            <div class="sui-normal">
                <a href="#" class="user-link">
                    <img style="width: 95%;border-radius: 50%" src="/media/{{ userInfo.avatar }}" width="120" alt=""><br>

                    <span style="text-align: center;padding-top: 209px">欢迎回来,</span>
                    <strong style="text-align: center;margin-top: 5px">{{ userInfo.username }}</strong>
                </a>
            </div>
        </div>
       <ul id="main-menu" class="">
            <li>
                <a href="/myapp/home">
                    <i class="entypo-gauge"></i>
                    <span>首页</span>
                </a>
            </li>
            <li >
                <a href="#">
                    <i class="entypo-user"></i>
                    <span>个人中心</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/selfInfo">
                            <span>个人信息</span>
                        </a>
                    </li>
                    <li >
                        <a href="/myapp/changePW">
                            <span>修改密码</span>
                        </a>
                    </li>
                </ul>
            </li>

            <li>
                <a href="/myapp/tableData">
                    <i class="entypo-newspaper"></i>
                    <span>数据总览</span>
                </a>

            </li>
            <li class="opened active">
                <a href="#">
                    <i class="entypo-chart-bar"></i>
                    <span>可视化</span>

                </a>
                <ul>
                    <li class="active">
                        <a href="/myapp/salary">
                            <i class="entypo-light-down"></i>
                            <span>薪资</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/company">
                            <i class="entypo-feather"></i>
                            <span>企业</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/companyTags">
                            <i class="entypo-lamp"></i>
                            <span>福利</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/edu">
                            <i class="entypo-graduation-cap"></i>
                            <span>学历分布</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/companyStatus">
                            <i class="entypo-network"></i>
                            <span>企业融资</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/address">
                            <i class="entypo-rocket"></i>
                            <span>城市类型</span>
                        </a>
                    </li>
                </ul>
            </li>

        </ul>
    </div>
    <div class="main-content">

        <div class="row" style="display: flex">
            <div style="margin-left: auto" class="col-md-6 col-sm-4 clearfix hidden-xs">

                <ul class="list-inline links-list pull-right">
                    <li class="sep"></li>

                    <li>
                        <a href="/myapp/logout">
                            注销 <i class="entypo-logout right"></i>
                        </a>
                    </li>
                </ul>

            </div>

        </div>
        <hr>
        <ol class="breadcrumb bc-3">
            <li>
                <a href="#">
                    <i class="entypo-home"></i>
                    可视化图表
                </a>
            </li>
            <li>
                <strong>薪资</strong>
            </li>
        </ol>
        <h2>薪资</h2>
        <br>
        <div class="row">
            <div class="col-md-12">
                <div class="panel panel-warning" data-collapsed="0">

                    <!-- panel head -->
                    <div class="panel-heading">
                        <div class="panel-title">选择输入框</div>

                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1"
                               class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>


                    <div class="panel-body">
                        <form action="/myapp/salary/" method="get">
                            <div class="col-md-4">
                                <select name="edu" class="form-control">
                                    {% if defaultedu == '不限' %}
                                        <option selected value="不限">不限</option>
                                    {% else %}
                                        <option value="不限">不限</option>
                                    {% endif %}
                                    {% for i in edus %}
                                        {% if i == defaultedu %}
                                            <option selected value="{{ i }}">{{ i }}</option>
                                        {% else %}
                                            <option value="{{ i }}">{{ i }}</option>
                                        {% endif %}
                                    {% endfor %}
                                </select>
                            </div>
                            <div class="col-md-4">
                                <select name="workexp" class="form-control">
                                    {% if defaultworkexp == '不限' %}
                                        <option selected value="不限">不限</option>
                                    {% else %}
                                        <option value="不限">不限</option>
                                    {% endif %}
                                    {% for i in workexps %}
                                        {% if i == defaultworkexp %}
                                            <option selected value="{{ i }}">{{ i }}</option>
                                        {% else %}
                                            <option value="{{ i }}">{{ i }}</option>
                                        {% endif %}
                                    {% endfor %}
                                </select>
                            </div>
                            <div class="col-md-4">
                                <button type="submit" class="btn btn-info">提交</button>
                            </div>
                        </form>
                    </div>

                </div>
                <div class="panel panel-default panel-shadow" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">薪资分布</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-3" class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body" style="text-align: center">
                        {% if legends == None %}
                            <i class="entypo-cloud" style="font-size: 100px">
                                <h1>None</h1>
                            </i>
                        {% else %}
                            <div id="main" style="width: 100%;height: 480px">
                        {% endif %}
                        </div>
                    </div>
                </div>
            </div>
            <div class="col-md-6">
                <div class="panel panel-default panel-shadow" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">实习生薪资平均值</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-3"
                               class="bg"><i
                                    class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body" style="text-align: center">
                        <div id="mainTwo" style="width: 100%;height: 450px">
                        </div>
                    </div>
                </div>
            </div>
            <div class="col-md-6">
                <div class="panel panel-default panel-shadow" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">年底多薪</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-3"
                               class="bg"><i
                                    class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body" style="text-align: center">
                        <div id="mainThree" style="width: 100%;height: 450px"></div>
                    </div>
                </div>
            </div>
        </div>
    </div>

<link rel="stylesheet" href="/static/css/jquery-jvectormap-1.2.2.css">
<link rel="stylesheet" href="/static/css/rickshaw.min.css">
<script src="/static/js/fileinput.js"></script>
<script src="/static/js/main-gsap.js"></script>
<script src="/static/js/jquery-ui-1.10.3.minimal.min.js"></script>
<script src="/static/js/bootstrap.js"></script>
<script src="/static/js/joinable.js"></script>
<script src="/static/js/resizeable.js"></script>
<script src="/static/js/neon-api.js"></script>
<script src="/static/js/jquery-jvectormap-1.2.2.min.js"></script>
<script src="/static/js/jquery-jvectormap-europe-merc-en.js"></script>
<script src="/static/js/jquery-jvectormap-world-mill-en.js"></script>
<script src="/static/js/jquery.sparkline.min.js"></script>
<script src="/static/js/d3.v3.js"></script>
<script src="/static/js/rickshaw.min.js"></script>
<script src="/static/js/neon-chat.js"></script>
<script src="/static/js/neon-custom.js"></script>
<script src="/static/js/neon-demo.js"></script>
<script src="/static/js/echarts.min.js"></script>
<script>
    var chartDom = document.getElementById('main');
    var myChart = echarts.init(chartDom);
    var option;
    option = {
        tooltip: {

            trigger: 'axis'
        },
        toolbox: {
            show: true,
            top: 'left',
            orient: 'vertical',
            feature: {

                dataView: {show: true, readOnly: false},
                magicType: {show: true, type: ['line', 'bar']},
                restore: {show: true},
                saveAsImage: {show: true}
            }
        },
        legend: {
            data: {{ legends |safe }}
        },
        xAxis: {
            type: 'category',
            data: {{ salarylist | safe }}
        },
        yAxis: {
            type: 'value'
        },
        series: [
            {% for k,v in barData.items %}
                {
                    name: '{{ k | safe }}',
                    type: 'bar',
                    data:{{ v | safe }},
                    markPoint: {
                        data: [
                            {type: 'max', name: 'Max'},
                            {type: 'min', name: 'Min'}
                        ]
                    }
                },
            {% endfor %}
        ],
    };
    option && myChart.setOption(option);
</script>
<script>
    var chartDom = document.getElementById('mainTwo');
    var myChart = echarts.init(chartDom);
    var option;
    const piePatternSrc =      '';
    const bgPatternSrc =
        '';
    const piePatternImg = new Image();
    piePatternImg.src = piePatternSrc;
    const bgPatternImg = new Image();
    bgPatternImg.src = bgPatternSrc;
    option = {
        backgroundColor: {
            image: bgPatternImg,
            repeat: 'repeat'
        },
        legend: {},
        toolbox: {
            top: 'left',
            orient: 'vertical',
            feature: {
                dataView: {readOnly: false},
                restore: {},
                saveAsImage: {}
            }
        },
        title: {
            text: '',
            textStyle: {
                color: '#235894'
            }
        },
        tooltip: {},
        series: [
            {
                name: '',
                type: 'pie',
                selectedMode: 'single',
                selectedOffset: 20,
                clockwise: true,

                label: {
                    fontSize: 12,
                    color: '#235894',
                    formatter:function(pieData){
	                  return `${pieData.name}
	 (${pieData.percent.toFixed(1)}%)`}
                },
                labelLine: {
                    lineStyle: {
                        color: '#235894'
                    }
                },
                data: {{ pieData | safe }},
                itemStyle: {
                    opacity: 0.5,
                    color: {
                        image: piePatternImg,
                        repeat: 'repeat'
                    },
                    borderWidth: 2,
                    borderColor: '#235894'
                }
            }
        ]
    };
    option && myChart.setOption(option);
</script>
<script>
    var chartDom = document.getElementById('mainThree');
    var myChart = echarts.init(chartDom);
    var option;
    option = {
        title: {
            text: ''
        },
        tooltip: {
            trigger: 'item',

            formatter: '{a} <br/>{b} : {c} 人'
        },
        toolbox: {
            top: 'left',
            orient: 'vertical',
            feature: {
                dataView: {readOnly: false},
                restore: {},
                saveAsImage: {}
            }
        },
        legend: {},
        series: [
            {
                name: 'Funnel',
                type: 'funnel',
                left: '10%',
                top: 60,
                bottom: 60,
                width: '80%',
                minSize: '0%',
                maxSize: '100%',
                sort: 'descending',
                gap: 2,
                label: {
                    show: true,
                    position: 'inside'
                },
                labelLine: {
                    length: 10,
                    lineStyle: {
                        width: 1,
                        type: 'solid'
                    }
                },
                itemStyle: {
                    borderColor: '#fff',
                    borderWidth: 1
                },
                emphasis: {
                    label: {
                        fontSize: 30
                    }
                },
                data: {{ loudou | safe }}
            }
        ]
    };
    option && myChart.setOption(option);
</script>
</body>
</html>

5.2企业页面

在views,编写企业分析的代码

def company(request):
    uname = request.session['username']
    userInfo = User.objects.get(username=uname)
    typeList = getCompany.getPage()
    type = 'all'
    if request.GET.get('type'):
        type = request.GET.get('type')
    rowData, colData = getCompany.getcompany(type)
    pieData = getCompany.getcompanyPie(type)
    companyPeo, listdata = getCompany.getCompanyPeo(type)
    return render(request, 'companyChart.html', {
        'userInfo': userInfo,
        'typeList': typeList,
        'type': type,
        'rowData': rowData,
        'colData': colData,
        'pieData': pieData,
        'companyPeo': companyPeo,
        'listdata': listdata
    })

对个企业分析,写在/myapp/utils中的 getCompany.py中,在views调用函数方法

from .getPublicData import *
from myapp.models import JobInfo
import json

def getPage():
    jobs = getAllJobs()
    type = []
    for i in jobs:
        type.append(i.type)
    return list(set(type))


def getcompany(type):
    if type == 'all':
        jobs = JobInfo.objects.all()
    else:
        jobs = JobInfo.objects.filter(type=type)
    natureData = {}
    for i in jobs:
        if natureData.get(i.companyNature, -1) == -1:
            natureData[i.companyNature] = 1
        else:
            natureData[i.companyNature] += 1
    natureDataList = list(sorted(natureData.items(), key=lambda x: x[1], reverse=True))
    rowData = []
    colData = []
    for k, v in natureDataList:
        rowData.append(k)
        colData.append(v)
    return rowData[:20], colData[:20]


def getcompanyPie(type):
    if type == 'all':
        jobs = JobInfo.objects.all()
    else:
        jobs = JobInfo.objects.filter(type=type)
    addressData = {}
    for i in jobs:
        if addressData.get(i.address, -1) == -1:
            addressData[i.address] = 1
        else:
            addressData[i.address] += 1
    result = []
    for k, v in addressData.items():
        result.append({
            'name': k,
            'value': v
        })
    return result[:20]


def getCompanyPeo(type):
    if type == 'all':
        jobs = JobInfo.objects.all()
    else:
        jobs = JobInfo.objects.filter(type=type)
    data = [0 for x in range(6)]
    for i in jobs:
        i.companyPeo = json.loads(i.companyPeo)[1]
        p = i.companyPeo
        if p <= 20:
            data[0] += 1
        elif p <= 100:
            data[1] += 1
        elif p <= 500:
            data[2] += 1
        elif p <= 1000:
            data[3] += 1
        elif p < 10000:
            data[4] += 1
        else:
            data[5] += 1
    return companyPeo,data

在/myapp/templates/下新建 companyChart.html页面,编写网页代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta name="description" content="Neon Admin Panel">
    <meta name="author" content="">
    <title>
        企业
    </title>
    <link rel="stylesheet" href="/static/css/jquery-ui-1.10.3.custom.min.css">
    <link rel="stylesheet" href="/static/css/entypo.css">
    <link rel="stylesheet" href="/static/css/css.css">
    <link rel="stylesheet" href="/static/css/bootstrap.css">
    <link rel="stylesheet" href="/static/css/neon-core.css">
    <link rel="stylesheet" href="/static/css/neon-theme.css">
    <link rel="stylesheet" href="/static/css/neon-forms.css">
    <link rel="stylesheet" href="/static/css/custom.css">
    <script src="/static/js/jquery-1.11.0.min.js"></script>
    <script src="/assets/js/ie8-responsive-file-warning.js"></script>
    <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
    <script src="https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js"></script>
</head>
<body class="page-body  page-left-in" data-url="http://neon.dev">
<div class="page-container">
    <div class="sidebar-menu">
        <header class="logo-env">
            <div class="logo">
                <a href="index.html">
                    <h3 style="color: #fff1f0;font-weight: bold;margin-top: 5px">岗位数据可视化</h3>
                </a>
            </div>
        </header>
        <div class="sidebar-user-info">
            <div class="sui-normal">
                <a href="#" class="user-link">
                    <img style="width: 95%;border-radius: 50%" src="/media/{{ userInfo.avatar }}" width="120" alt=""><br>

                    <span style="text-align: center;padding-top: 209px">欢迎回来,</span>
                    <strong style="text-align: center;margin-top: 5px">{{ userInfo.username }}</strong>
                </a>
            </div>
        </div>
         <ul id="main-menu" class="">
            <li>
                <a href="/myapp/home">
                    <i class="entypo-gauge"></i>
                    <span>首页</span>
                </a>
            </li>
            <li>
                <a href="#">
                    <i class="entypo-user"></i>
                    <span>个人中心</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/selfInfo">
                            <span>个人信息</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/changePW">
                            <span>修改密码</span>
                        </a>
                    </li>
                </ul>
            </li>
            <li>
                <a href="/myapp/tableData">
                    <i class="entypo-newspaper"></i>
                    <span>数据总览</span>
                </a>
            </li>
            <li class="opened active">
                <a href="#">
                    <i class="entypo-chart-bar"></i>
                    <span>可视化</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/salary">
                            <i class="entypo-light-down"></i>
                            <span>薪资</span>
                        </a>
                    </li>
                    <li class="active">
                        <a href="/myapp/company">
                            <i class="entypo-feather"></i>
                            <span>企业</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/companyTags">
                            <i class="entypo-lamp"></i>
                            <span>福利</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/edu">
                            <i class="entypo-graduation-cap"></i>
                            <span>学历分布</span>
                        </a>
                    </li>
                    <li >
                        <a href="/myapp/companyStatus">
                            <i class="entypo-network"></i>
                            <span>企业融资</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/address">
                            <i class="entypo-rocket"></i>
                            <span>城市类型</span>
                        </a>
                    </li>
                </ul>
            </li>

        </ul>
    </div>
    <div class="main-content">
        <div class="row" style="display: flex">
            <div style="margin-left: auto" class="col-md-6 col-sm-4 clearfix hidden-xs">
                <ul class="list-inline links-list pull-right">
                    <li class="sep"></li>
                    <li>
                        <a href="/myapp/logout">
                            注销 <i class="entypo-logout right"></i>
                        </a>
                    </li>
                </ul>
            </div>
        </div>
        <hr>
        <ol class="breadcrumb bc-3">
            <li>
                <a href="#">
                    <i class="entypo-home"></i>
                    可视化图表
                </a>
            </li>
            <li>
                <strong>企业</strong>
            </li>
        </ol>
        <h2>企业</h2>
        <br>
        <div class="row">
            <div class="col-md-12">
                <div class="panel panel-warning" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">选择职业</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1"
                               class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div class="btn-group">
                            {% if type == 'all' %}
                                <a href="#" type="button" class="btn btn-success">全部</a>
                            {% else %}
                                <a href="/myapp/company?type=all" type="button" class="btn btn-default">全部</a>
                            {% endif %}
                            {% for i in typeList %}
                                {% if i == type %}
                                    <a href="#" type="button" class="btn btn-success">{{ i }}</a>
                                {% else %}
                                    <a href="/myapp/company?type={{ i }}" type="button"
                                       class="btn btn-default">{{ i }}</a>
                                {% endif %}
                            {% endfor %}
                        </div>
                    </div>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-md-6">
                <div class="panel panel-success" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">行业数量</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i  class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div id="main" style="width: 100%;height: 450px"></div>
                    </div>
                </div>
            </div>
            <div class="col-md-6">
                <div class="panel panel-success" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">公司地址</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div id="mainTwo" style="width: 100%;height: 450px"></div>
                    </div>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-md-12">
                <div class="panel panel-dark" data-collapsed="0">        
                    <div class="panel-heading">
                        <div class="panel-title">公司人数</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div id="mainThree" style="width: 100%;height: 450px"></div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>
<link rel="stylesheet" href="/static/css/jquery-jvectormap-1.2.2.css">
<link rel="stylesheet" href="/static/css/rickshaw.min.css">
<script src="/static/js/fileinput.js"></script>
<script src="/static/js/main-gsap.js"></script>
<script src="/static/js/jquery-ui-1.10.3.minimal.min.js"></script>
<script src="/static/js/bootstrap.js"></script>
<script src="/static/js/joinable.js"></script>
<script src="/static/js/resizeable.js"></script>
<script src="/static/js/neon-api.js"></script>
<script src="/static/js/jquery-jvectormap-1.2.2.min.js"></script>
<script src="/static/js/jquery-jvectormap-europe-merc-en.js"></script>
<script src="/static/js/jquery-jvectormap-world-mill-en.js"></script>
<script src="/static/js/jquery.sparkline.min.js"></script>
<script src="/static/js/d3.v3.js"></script>
<script src="/static/js/rickshaw.min.js"></script>
<script src="/static/js/neon-chat.js"></script>
<script src="/static/js/neon-custom.js"></script>
<script src="/static/js/neon-demo.js"></script>
<script src="/static/js/echarts.min.js"></script>
<script>
    var chartDom = document.getElementById('main');
    var myChart = echarts.init(chartDom);
    var option;
    option = {
        tooltip: {
            trigger: 'axis'
        },
        toolbox: {
            show: true,
            feature: {
                dataView: {show: true, readOnly: false},
                magicType: {show: true, type: ['line', 'bar']},
                restore: {show: true},
                saveAsImage: {show: true}
            }
        },
        color: ['#707f9b'],
        legend: {
            data: ['行业个数']
        },
        xAxis: {
            type: 'category',
            data: {{ rowData | safe }}
        },
        yAxis: {
            type: 'value'
        },
        series: [
            {
                name: '行业个数',
                data: {{ colData | safe }},
                type: 'bar',
                markPoint: {
                    data: [
                        {type: 'max', name: 'Max'},
                        {type: 'min', name: 'Min'}
                    ]
                },
                markLine: {
                    data: [{type: 'average', name: 'AVG'}]
                },
                itemStyle: {
                    normal: {
                        color: (parama) => {
                            var colorList = ['#00008b', '#ffde00', '#ed2939', '#dc143c', '#00247d'];
                            return colorList[Math.floor(Math.random() * colorList.length)]
                        }
                    }
                }

            }
        ]
    };
    option && myChart.setOption(option);
</script>
<script>
    var chartDom = document.getElementById('mainTwo');
    var myChart = echarts.init(chartDom);
    var option;
    option = {
        tooltip: {
            trigger: 'item',
        },
        toolbox: {
            show: true,
            feature: {
                dataView: {show: true, readOnly: false},
                restore: {show: true},
                saveAsImage: {show: true}
            }
        },
        legend: {
            top: '3%',
            x: 'left',
            y: 'top',
            orient: 'vartical',
            selectedMode: false
        },
        series: [
            {
                name: ',
                type: 'pie',
                radius: ['30%', '60%'],
                data:  {{ pieData |safe }},
                left: '25%',
                top: '5%',
                label:{
                     fontSize: 12,
                     formatter:function(pieData){
	                  return `${pieData.name}
(${pieData.percent.toFixed(1)}%)`}
                },
            },

        ]
    };
    option && myChart.setOption(option);
</script>
<script>
    var chartDom = document.getElementById('mainThree');
    var myChart = echarts.init(chartDom);
    var option;

    option = {
        title: {},
        tooltip: {
            trigger: 'item',
            axisPointer: {
                lineStyle: {
                    width: 3,
                    color: '#019688'
                }
            }
        },
        gird: {
            left: '4%',
            right: '3%',
            bottom: '3%',
            containLabel: true,
        },
        toolbox: {
            show: true,
            feature: {

                dataView: {show: true, readOnly: false},

                restore: {show: true},
                saveAsImage: {show: true}

            }
        },
        legend: {},
        label:{},
        grid: {
            left: '3%',
            right: '4%',
            bottom: '3%',
            containLabel: true
        },
        xAxis: [
            {
                type: 'category',
                boundaryGap: false,
                data: {{ companyPeo | safe }}
            }
        ],
        yAxis: [
            {
                type: 'value',
                max:1000,
                right:'3%'
            }
        ],
        series: [
            {
                name: '公司人数',
                type: 'line',
                stack: 'Total',
                smooth: true,
                areaStyle: {},
                emphasis: {
                    focus: 'series'
                },
                data: {{ listdata | safe }}
            },

        ]
    };
    option && myChart.setOption(option);
</script>
</body>
</html>

5.3福利页面

在views,编写福利分析的代码

def companyTags(request):
    uname = request.session['username']
    userInfo = User.objects.get(username=uname)
    world_cloud.getImg_tags_no('companyTags', './static/3.png', './static/img_tag.png')
    world_cloud.getImg_title('companyTitle', './static/2.png', './static/img_title.png')
    return render(request, 'companyWord.html', {
        'userInfo': userInfo,
    })

对个福利分析,写在/myapp/下的world_cloud.py中,在views调用函数方法

import jieba
from matplotlib import pylab as plt
from PIL import Image
import numpy as np
from wordcloud import WordCloud
import pymysql
import json
def getImg_title(filed, targetImage, resImage):
    #连接数据库
    con = pymysql.connect(host='localhost', user='root', password='xxxx', db='boss', port=3306, charset='utf8mb4')
    cursor = con.cursor()
    sql = "select  {}  from joninfo".format(filed)
    cursor.execute(sql)
    data = cursor.fetchall()
    text = ''
    for i in data:
        text +=i[0]
    cursor.close()
    con.close()
    data_cut = jieba.cut(text, cut_all=False)
    stop_words = []
    with open('.\stopwords.txt', 'r', encoding='utf8') as f:
        for line in f:
            if len(line) > 0:
                stop_words.append(line.strip())
    data_result = [x for x in data_cut if x not in stop_words]
    string = ' '.join(data_result)
    img = Image.open(targetImage)
    img_arr = np.array(img)
    wc = WordCloud(
        background_color='white',
        mask=img_arr,
        font_path='simhei.ttf',
    )
    wc.generate_from_text(string)
    fig=plt.figure(1)
    plt.imshow(wc)
    plt.axis('off')
    plt.savefig(resImage,dpi=800)

    
def getImg_tags_no(filed, targetImage, resImage):
    con = pymysql.connect(host='localhost', user='root', password='675041', db='boss', port=3307, charset='utf8mb4')
    cursor = con.cursor()
    sql = "select  {}  from joninfo".format(filed)
    cursor.execute(sql)
    data = cursor.fetchall()
    text = ''
    for i in data:
        if i[0] != '无':
            companyArr = json.loads(i[0])[0].split(',')
            for j in companyArr:
                text += j
    cursor.close()
    con.close()
    data_cut = jieba.cut(text, cut_all=False)
    string = ' '.join(data_cut)

    img = Image.open(targetImage)
    img_arr = np.array(img)
    wc = WordCloud(
        background_color='white',
        mask=img_arr,
        font_path='simhei.ttf',
    )
    wc.generate_from_text(string)
    fig=plt.figure(1)
    plt.imshow(wc)
    plt.axis('off')
    plt.savefig(resImage,dpi=800)

在/myapp/templates/下新建companyWord.html页面,编写网页代码

{% load static %}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta name="description" content="Neon Admin Panel">
    <meta name="author" content="">
    <title>
        福利
    </title>
    <link rel="stylesheet" href="/static/css/jquery-ui-1.10.3.custom.min.css">
    <link rel="stylesheet" href="/static/css/entypo.css">
    <link rel="stylesheet" href="/static/css/css.css">
    <link rel="stylesheet" href="/static/css/bootstrap.css">
    <link rel="stylesheet" href="/static/css/neon-core.css">
    <link rel="stylesheet" href="/static/css/neon-theme.css">
    <link rel="stylesheet" href="/static/css/neon-forms.css">
    <link rel="stylesheet" href="/static/css/custom.css">
    <script src="/static/js/jquery-1.11.0.min.js"></script>
    <script src="/assets/js/ie8-responsive-file-warning.js"></script>
    <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
    <script src="https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js"></script>
</head>
<body class="page-body  page-left-in" data-url="http://neon.dev">
<div class="page-container">
    <div class="sidebar-menu">
        <header class="logo-env">
            <div class="logo">
                <a href="index.html">
                    <h3 style="color: #fff1f0;font-weight: bold;margin-top: 5px">岗位数据可视化</h3>
                </a>
            </div>
        </header>
        <div class="sidebar-user-info">
            <div class="sui-normal">
                <a href="#" class="user-link">
                    <img style="width: 95%;border-radius: 50%" src="/media/{{ userInfo.avatar }}" width="120" alt=""><br>
                    <span style="text-align: center;padding-top: 209px">欢迎回来,</span>
                    <strong style="text-align: center;margin-top: 5px">{{ userInfo.username }}</strong>
                </a>
            </div>
        </div>
        <ul id="main-menu" class="">
​
            <li>
                <a href="/myapp/home">
                    <i class="entypo-gauge"></i>
                    <span>首页</span>
                </a>
            </li>
            <li>
                <a href="#">
                    <i class="entypo-user"></i>
                    <span>个人中心</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/selfInfo">
                            <span>个人信息</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/changePW">
                            <span>修改密码</span>
                        </a>
                    </li>
                </ul>
            </li>
            <li>
                <a href="/myapp/tableData">
                    <i class="entypo-newspaper"></i>
                    <span>数据总览</span>
                </a>
            </li>
            <li class="opened active">
                <a href="#">
                    <i class="entypo-chart-bar"></i>
                    <span>可视化</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/salary">
                            <i class="entypo-light-down"></i>
                            <span>薪资</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/company">
                            <i class="entypo-feather"></i>
                            <span>企业</span>
                        </a>
                    </li>
                    <li class="active">
                        <a href="/myapp/companyTags">
                            <i class="entypo-lamp"></i>
                            <span>福利</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/edu">
                            <i class="entypo-graduation-cap"></i>
                            <span>学历分布</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/companyStatus">
                            <i class="entypo-network"></i>
                            <span>企业融资</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/address">
                            <i class="entypo-rocket"></i>
                            <span>城市类型</span>
                        </a>
                    </li>
                </ul>
            </li>
        </ul>
    </div>
    <div class="main-content">
        <div class="row" style="display: flex">
            <div style="margin-left: auto" class="col-md-6 col-sm-4 clearfix hidden-xs">
                <ul class="list-inline links-list pull-right">
                    <li class="sep"></li>
​
                    <li>
                        <a href="/myapp/logout">
                            注销 <i class="entypo-logout right"></i>
                        </a>
                    </li>
                </ul>
            </div>
​
        </div>
        <hr>
        <ol class="breadcrumb bc-3">
            <li>
                <a href="#">
                    <i class="entypo-home"></i>
                    可视化图表
                </a>
            </li>
            <li>
                <strong>福利</strong>
            </li>
        </ol>
        <h2>福利</h2>
        <br>
        <div class="row">
            <div class="col-md-6">
                <div class="panel panel-info" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">公司福利</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <img style="width: 100%" src="{% static 'img_tag.png' %}" alt="">
                    </div>
                </div>
            </div>
            <div class="col-md-6">
                <div class="panel panel-info" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">公司标签</div>
​
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <img style="width: 100%" src="{% static 'img_title.png' %}" alt="">
                    </div>
​
                </div>
​
            </div>
        </div>
    </div>
        <div class="row">
            <div class="col-md-6">
                <div class="panel panel-success" data-collapsed="0">
                </div>
            </div>
        </div>  
            <div class="col-md-6">
                <div class="panel panel-success" data-collapsed="0"></div>
            </div>
        </div>
<link rel="stylesheet" href="/static/css/jquery-jvectormap-1.2.2.css">
<link rel="stylesheet" href="/static/css/rickshaw.min.css">
<script src="/static/js/fileinput.js"></script>
<script src="/static/js/main-gsap.js"></script>
<script src="/static/js/jquery-ui-1.10.3.minimal.min.js"></script>
<script src="/static/js/bootstrap.js"></script>
<script src="/static/js/joinable.js"></script>
<script src="/static/js/resizeable.js"></script>
<script src="/static/js/neon-api.js"></script>
<script src="/static/js/jquery-jvectormap-1.2.2.min.js"></script>
<script src="/static/js/jquery-jvectormap-europe-merc-en.js"></script>
<script src="/static/js/jquery-jvectormap-world-mill-en.js"></script>
<script src="/static/js/jquery.sparkline.min.js"></script>
<script src="/static/js/d3.v3.js"></script>
<script src="/static/js/rickshaw.min.js"></script>
<script src="/static/js/neon-chat.js"></script>
<script src="/static/js/neon-custom.js"></script>
<script src="/static/js/neon-demo.js"></script>
<script src="/static/js/echarts.min.js"></script>
</body>
</html>

5.4学历分布页面

在views,编写学历分布分析的代码

def edu(request):
    uname = request.session['username']
    userInfo = User.objects.get(username=uname)
    defaultedu = '不限'
    if request.GET.get('edu'):
        defaultedu = request.GET.get('edu')
    edus = geteduData.getPage()
    workExps, charDataOne, charDataTwo, hasEmpty = geteduData.getExp(defaultedu)
    barRow, barCol = geteduData.getPeo()
    return render(request, 'education.html', {
        'userInfo': userInfo,
        'defaultedu': defaultedu,
        'edus': edus,
        'workExps': workExps,
        'charDataOne': charDataOne,
        'charDataTwo': charDataTwo,
        'hasEmpty': hasEmpty,
        'barRow': barRow,
        'barCol': barCol
    })

对个学历分布分析,写在/myapp/utils中的 geteduData.py中,在views调用函数方法

import json
from .getPublicData import *
from myapp.models import JobInfo
def getPage():
    return list(edus.keys())
​
​
def getAverged(list):
    result = 0
    for i in list:
        result += i
    return round(result / len(list), 2)
​
​
def getExp(edution):
    hasEmpty = False
    if edution == "不限":
        jobs = JobInfo.objects.all()
    else:
        jobs = JobInfo.objects.filter(edu=edution)
    workExps = {}
    workpeo = {}
    for i in workexp:
        workExps[i] = []
        workpeo[i] = 0
    for job in jobs:
        for k, v in workExps.items():
            if job.workexp == k:
                if job.pratice == '0':
                    workExps[k].append(json.loads(job.salary)[1])
                    workpeo[k] += 1
    for k, v in workExps.items():
        try:
            workExps[k] = getAverged(v)
        except:
            workExps[k] = 0
    if len(jobs) == 0:
        hasEmpty = True
    return workexp, list(workExps.values()), list(workpeo.values()), hasEmpty
​
def getPeo():
    jobs=getAllJobs()
    educationData={}
    for i in jobs:
        if educationData.get(i.edu,-1)==-1:
            educationData[i.edu]=1
        else:
            educationData[i.edu]+=1
    return list(educationData.keys()),list(educationData.values())

在/myapp/templates/下新建education.html页面,编写网页代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta name="description" content="Neon Admin Panel">
    <meta name="author" content="">
    <title>
        学历分布
    </title>
    <link rel="stylesheet" href="/static/css/jquery-ui-1.10.3.custom.min.css">
    <link rel="stylesheet" href="/static/css/entypo.css">
    <link rel="stylesheet" href="/static/css/css.css">
    <link rel="stylesheet" href="/static/css/bootstrap.css">
    <link rel="stylesheet" href="/static/css/neon-core.css">
    <link rel="stylesheet" href="/static/css/neon-theme.css">
    <link rel="stylesheet" href="/static/css/neon-forms.css">
    <link rel="stylesheet" href="/static/css/custom.css">
    <script src="/static/js/jquery-1.11.0.min.js"></script>
    <script src="/assets/js/ie8-responsive-file-warning.js"></script>
    <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
    <script src="https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js"></script>
</head>
<body class="page-body  page-left-in" data-url="http://neon.dev">
<div class="page-container">
    <div class="sidebar-menu">
        <header class="logo-env">
            <div class="logo">
                <a href="index.html">
                    <h3 style="color: #fff1f0;font-weight: bold;margin-top: 5px">岗位数据可视化</h3>
                </a>
            </div>
</header>
      <div class="sidebar-user-info">
            <div class="sui-normal">
                <a href="#" class="user-link">
                    <img style="width: 95%;border-radius: 50%" src="/media/{{ userInfo.avatar }}" width="120" alt=""><br>
                   <span style="text-align: center;padding-top: 209px">欢迎回来,</span>
                    <strong style="text-align: center;margin-top: 5px">{{ userInfo.username }}</strong>
                </a>
            </div>
        </div>
         <ul id="main-menu" class="">
            <li>
                <a href="/myapp/home">
                    <i class="entypo-gauge"></i>
                    <span>首页</span>
                </a>
            </li>
            <li>
                <a href="#">
                    <i class="entypo-user"></i>
                    <span>个人中心</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/selfInfo">
                            <span>个人信息</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/changePW">
                            <span>修改密码</span>
                        </a>
                    </li>
                </ul>
            </li>
            <li>
                <a href="/myapp/tableData">
                    <i class="entypo-newspaper"></i>
                    <span>数据总览</span>
                </a>
            </li>
            <li class="opened active">
                <a href="#">
                    <i class="entypo-chart-bar"></i>
                    <span>可视化</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/salary">
                            <i class="entypo-light-down"></i>
                            <span>薪资</span>
                        </a>
                    </li>
                    <li >
                        <a href="/myapp/company">
                            <i class="entypo-feather"></i>
                            <span>企业</span>
                        </a>
                    </li>
                    <li >
                        <a href="/myapp/companyTags">
                            <i class="entypo-lamp"></i>
                            <span>福利</span>
                        </a>
                    </li>
                    <li class="active">
                        <a href="/myapp/edu">
                            <i class="entypo-graduation-cap"></i>
                            <span>学历分布</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/companyStatus">
                            <i class="entypo-network"></i>
                            <span>企业融资</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/address">
                            <i class="entypo-rocket"></i>
                            <span>城市类型</span>
                        </a>
                    </li>
                </ul>
            </li>
        </ul>
    </div>
    <div class="main-content">
        <div class="row" style="display: flex">
            <div style="margin-left: auto" class="col-md-6 col-sm-4 clearfix hidden-xs">
                <ul class="list-inline links-list pull-right">
                    <li class="sep"></li>
                    <li>
                        <a href="/myapp/logout">
                            注销 <i class="entypo-logout right"></i>
                        </a>
                    </li>
               </ul>
            </div>
        </div>
        <hr>
        <ol class="breadcrumb bc-3">
            <li>
                <a href="#">
                    <i class="entypo-home"></i>
                    可视化图表
                </a>
            </li>
            <li>
                <strong>学历分布</strong>
            </li>
        </ol>
        <h2>学历分布</h2>
        <br>
        <div class="row">
            <div class="col-md-6">
                <div class="panel panel-warning" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">选择输入框</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1"
                               class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <form action="/myapp/edu/" method="get">
                            <div class="col-md-4">
                                <select name="edu" class="form-control">
                                    {% if defaultedu == '不限' %}
                                        <option selected value="不限">不限</option>
                                    {% else %}
                                        <option value="不限">不限</option>
                                    {% endif %}
                                    {% for i in edus %}
                                        {% if i == defaultedu %}
                                            <option selected value="{{ i }}">{{ i }}</option>
                                        {% else %}
                                            <option value="{{ i }}">{{ i }}</option>
                                        {% endif %}
                                    {% endfor %}
                                </select>
                            </div>
                            <button type="submit" class="btn btn-info">提交</button>
                        </form>
                    </div>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-md-6">
                <div class="panel panel-success" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">工作年薪涨幅情况</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        {% if hasEmpty %}
                            <i class="entypo-cloud" style="font-size: 100px">
                                <h1>None</h1>
                            </i>
                        {% else %}
                            <div id="main" style="width: 100%;height: 450px">
                        {% endif %}
                        </div>
                    </div>
                </div>
            </div>
            <div class="col-md-6">
                <div class="panel panel-success" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">学历人数</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1"
                               class="bg"><i
                                    class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div id="mainTwo" style="width: 100%;height: 450px"></div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>
<link rel="stylesheet" href="/static/css/jquery-jvectormap-1.2.2.css">
<link rel="stylesheet" href="/static/css/rickshaw.min.css">
<script src="/static/js/fileinput.js"></script>
<script src="/static/js/main-gsap.js"></script>
<script src="/static/js/jquery-ui-1.10.3.minimal.min.js"></script>
<script src="/static/js/bootstrap.js"></script>
<script src="/static/js/joinable.js"></script>
<script src="/static/js/resizeable.js"></script>
<script src="/static/js/neon-api.js"></script>
<script src="/static/js/jquery-jvectormap-1.2.2.min.js"></script>
<script src="/static/js/jquery-jvectormap-europe-merc-en.js"></script>
<script src="/static/js/jquery-jvectormap-world-mill-en.js"></script>
<script src="/static/js/jquery.sparkline.min.js"></script>
<script src="/static/js/d3.v3.js"></script>
<script src="/static/js/rickshaw.min.js"></script>
<script src="/static/js/neon-chat.js"></script>
<script src="/static/js/neon-custom.js"></script>
<script src="/static/js/neon-demo.js"></script>
<script src="/static/js/echarts.min.js"></script>
<script>
        var chartDom = document.getElementById('main');
        var myChart = echarts.init(chartDom);
        var option;
        const colors = ['#5470C6', '#91CC75'];
        option = {
            color: colors,
            tooltip: {
                trigger: 'axis',
                axisPointer: {
                    type: 'cross'
                }
            },
            grid: {
                right: '20%'
            },
            toolbox: {
                feature: {
                    dataView: {show: true, readOnly: false},
                    magicType: {show: true, type: ['line', 'bar']},
                    restore: {show: true},
                    saveAsImage: {show: true},

                }
            },
            legend: {},
            xAxis: [
                {
                    type: 'category',
                    axisTick: {
                        alignWithLabel: true
                    },     
                    data: {{ workExps | safe }}
                }
            ],
            yAxis: [
                {
                    type: 'value',
                    name: '薪资平均值',
                    position: 'left',
                    alignTicks: true,
                    axisLine: {
                        show: true,
                        lineStyle: {
                            color: colors[0]
                        }
                    },
                    axisLabel: {
                        formatter: '{value} $'
                    },
                    splitLine: {show: false}
                },
                {
                    type: 'value',
                    name: '人数',
                    position: 'right',
                    alignTicks: true,
                    offset: 50,
                    axisLine: {
                        show: true,
                        lineStyle: {
                            color: colors[1]
                        }
                    },
                    axisLabel: {
                        formatter: '{value} 人 '
                    }
                }
            ],
            series: [
                {
                    name: '薪资平均值',
                    type: 'bar',
                    data: {{ charDataOne | safe }},
                    markPoint: {
                        data: [
                            {type: 'max', name: 'Max'},
                            {type: 'min', name: 'Min'}
                        ]
                    },
                    markLine: {
                        data: [{type: 'average', name: 'AVG'}]
                    },
                },
                {
                    name: '人数',
                    type: 'bar',
                    yAxisIndex: 1,
                    data: {{ charDataTwo | safe }}
                }
            ]
        };
        option && myChart.setOption(option);
</script>
<script>
        var chartDom = document.getElementById('mainTwo');
        var myChart = echarts.init(chartDom);
        var option;
        option = {
            title: {
                text: '学历人数'
            },
            tooltip: {
                trigger: 'axis',
                axisPointer: {
                    type: 'shadow'
                }
            },
             toolbox: {
                feature: {
                    dataView: {show: true, readOnly: false},
                    magicType: {show: true, type: ['line', 'bar']},
                    restore: {show: true},
                    saveAsImage: {show: true},
                }
            },
            legend: {},
            grid: {
                left: '3%',
                right: '4%',
                bottom: '3%',
                containLabel: true
            },
            xAxis: {
                type: 'value',
                boundaryGap: [0, 0.01],
            },
            yAxis: {
                type: 'category',
                data:{{ barRow | safe }}
            },
            series: [
                {
                    name: '人数',
                    type: 'bar',
                    data: {{ barCol | safe }},
                    markPoint: {
                        data: [
                            {type: 'max', name: 'Max'},
                            {type: 'min', name: 'Min'}
                        ]
                    },
                    markLine: {
                        data: [{type: 'average', name: 'AVG'}]
                    },
                    itemStyle: {
                        normal: {
                            color: (parama) => {
                                var colorList = ['#00008b', '#ffde00', '#ed2939', '#dc143c', '#00247d'];
                                return colorList[Math.floor(Math.random() * colorList.length)]
                            }
                        }
                    }
                }
            ]
        };
        option && myChart.setOption(option);
</script>
</body>
</html>

5.5企业融资页面

在views,编写企业融资分析的代码

def companyStatus(request):
    uname = request.session['username']
    userInfo = User.objects.get(username=uname)
    defaultType = '不限'
    if request.GET.get('type'):
        defaultType = request.GET.get('type')
    typeList = getCompanyStatus.getPage()
    techologyRow, techologyCol = getCompanyStatus.getCompanyTechoData(defaultType)
    CompanyStuData = getCompanyStatus.getCompanyStuData()
    return render(request, 'companyStatus.html', {
        'userInfo': userInfo,
        'typeList': typeList,
        'defaultType': defaultType,
        'techologyRow': techologyRow,
        'techologyCol': techologyCol,
        'CompanyStuData': CompanyStuData
    })

对个企业融资分析,写在/myapp/utils中的getCompanyStatus.py中,在views调用函数方法

import json
from .getPublicData import *
from myapp.models import JobInfo
def getPage():
    job = []
    jobs = getAllJobs()
    for i in jobs:
        job.append(i.type)
    return list(set(job))
​
​
def getCompanyTechoData(type):
    if type == '不限':
        jobs = JobInfo.objects.all()
    else:
        jobs = JobInfo.objects.filter(type=type)
    workTagData = {}
    for job in jobs:
        workTag = json.loads(job.workTag)
        for w in workTag:
            if not w:
                break
            if workTagData.get(w, -1) == -1:
                workTagData[w] = 1
            else:
                workTagData[w] += 1
    result = sorted(workTagData.items(), key=lambda x: x[1], reverse=True)[:20]
    techologyRow = []
    techologyCol = []
    for k, v in result:
        techologyRow.append(k)
        techologyCol.append(v)
    return techologyRow, techologyCol
​
​
​
def getCompanyStuData():
    jobs=getAllJobs()
    statusData={}
    for job in jobs:
        if statusData.get(job.companyStatus,-1)==-1:
            statusData[job.companyStatus]=1
        else:
            statusData[job.companyStatus]+=1
    result=[]
    for k, v in statusData.items():
        result.append({
            'name':k,
            'value':v
        })
    return  result

在/myapp/templates/下新建companyStatus.html页面,编写网页代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta name="description" content="Neon Admin Panel">
    <meta name="author" content="">
    <title>
        企业融资
    </title>
    <link rel="stylesheet" href="/static/css/jquery-ui-1.10.3.custom.min.css">
    <link rel="stylesheet" href="/static/css/entypo.css">
    <link rel="stylesheet" href="/static/css/css.css">
    <link rel="stylesheet" href="/static/css/bootstrap.css">
    <link rel="stylesheet" href="/static/css/neon-core.css">
    <link rel="stylesheet" href="/static/css/neon-theme.css">
    <link rel="stylesheet" href="/static/css/neon-forms.css">
    <link rel="stylesheet" href="/static/css/custom.css">
    <script src="/static/js/jquery-1.11.0.min.js"></script>
    <script src="/assets/js/ie8-responsive-file-warning.js"></script>
    <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
    <script src="https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js"></script>
</head>
<body class="page-body  page-left-in" data-url="http://neon.dev">
<div class="page-container">
    <div class="sidebar-menu">
        <header class="logo-env">
            <div class="logo">
                <a href="index.html">
                    <h3 style="color: #fff1f0;font-weight: bold;margin-top: 5px">岗位数据可视化</h3>
                </a>
            </div>
        </header>
        <div class="sidebar-user-info">
           <div class="sui-normal">
                <a href="#" class="user-link">
                    <img style="width: 95%;border-radius: 50%" src="/media/{{ userInfo.avatar }}" width="120" alt=""><br>
                   <span style="text-align: center;padding-top: 209px">欢迎回来,</span>
                    <strong style="text-align: center;margin-top: 5px">{{ userInfo.username }}</strong>
                </a>
            </div>
            
        </div>
        <ul id="main-menu" class="">
            <li>
                <a href="/myapp/home">
                    <i class="entypo-gauge"></i>
                    <span>首页</span>
                </a>
            </li>
            <li>
                <a href="#">
                    <i class="entypo-user"></i>
                    <span>个人中心</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/selfInfo">
                            <span>个人信息</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/changePW">
                            <span>修改密码</span>
                        </a>
                    </li>
                </ul>
            </li>

            <li>
                <a href="/myapp/tableData">
                    <i class="entypo-newspaper"></i>
                    <span>数据总览</span>
                </a>
            </li>
            <li class="opened active">
                <a href="#">
                    <i class="entypo-chart-bar"></i>
                    <span>可视化</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/salary">
                            <i class="entypo-light-down"></i>
                            <span>薪资</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/company">
                            <i class="entypo-feather"></i>
                            <span>企业</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/companyTags">
                            <i class="entypo-lamp"></i>
                            <span>福利</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/edu">
                            <i class="entypo-graduation-cap"></i>
                            <span>学历分布</span>
                        </a>
                    </li>
                    <li class="active">
                        <a href="/myapp/companyStatus">
                            <i class="entypo-network"></i>
                            <span>企业融资</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/address">
                            <i class="entypo-rocket"></i>
                            <span>城市类型</span>
                        </a>
                    </li>
                </ul>
            </li>
        </ul>
    </div>
    <div class="main-content">
        <div class="row" style="display: flex">
            <div style="margin-left: auto" class="col-md-6 col-sm-4 clearfix hidden-xs">
                <ul class="list-inline links-list pull-right">
                    <li class="sep"></li>
                    <li>
                        <a href="/myapp/logout">
                            注销 <i class="entypo-logout right"></i>
                        </a>
                    </li>
               </ul>
            </div>
        </div>
        <hr>
        <ol class="breadcrumb bc-3">
            <li>
                <a href="#">
                    <i class="entypo-home"></i>
                    可视化图表
                </a>
            </li>
            <li>
                <strong>企业融资</strong>
            </li>
        </ol>
        <h2>企业融资</h2>
        <br>
        <div class="row">
            <div class="col-md-6">
                <div class="panel panel-warning" data-collapsed="0">              
                    <div class="panel-heading">
                        <div class="panel-title">选择输入框</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1"
                               class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <form action="/myapp/companyStatus/" method="get">
                            <div class="col-md-4">
                                <select name="type" class="form-control">
                                    {% if defaultType == '不限' %}
                                        <option selected value="不限">不限</option>
                                    {% else %}
                                        <option value="不限">不限</option>
                                    {% endif %}
                                    {% for i in typeList %}
                                        {% if i == defaultType %}
                                            <option selected value="{{ i }}">{{ i }}</option>
                                        {% else %}
                                            <option value="{{ i }}">{{ i }}</option>
                                        {% endif %}
                                    {% endfor %}
                                </select>
                            </div>
                            <button type="submit" class="btn btn-info">提交</button>
                        </form>
                    </div>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-md-12">
                <div class="panel panel-success" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">市场技术排行</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i  class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div id="main" style="width: 100%;height: 450px">
                        </div>

                    </div>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-md-8">
                <div class="panel panel-success" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">公司融资情况</div>

                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1"
                               class="bg"><i
                                    class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div id="mainTwo" style="width: 100%;height: 450px"></div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>
<link rel="stylesheet" href="/static/css/jquery-jvectormap-1.2.2.css">
<link rel="stylesheet" href="/static/css/rickshaw.min.css">
<script src="/static/js/fileinput.js"></script>
<script src="/static/js/main-gsap.js"></script>
<script src="/static/js/jquery-ui-1.10.3.minimal.min.js"></script>
<script src="/static/js/bootstrap.js"></script>
<script src="/static/js/joinable.js"></script>
<script src="/static/js/resizeable.js"></script>
<script src="/static/js/neon-api.js"></script>
<script src="/static/js/jquery-jvectormap-1.2.2.min.js"></script>
<script src="/static/js/jquery-jvectormap-europe-merc-en.js"></script>
<script src="/static/js/jquery-jvectormap-world-mill-en.js"></script>
<script src="/static/js/jquery.sparkline.min.js"></script>
<script src="/static/js/d3.v3.js"></script>
<script src="/static/js/rickshaw.min.js"></script>
<script src="/static/js/neon-chat.js"></script>
<script src="/static/js/neon-custom.js"></script>
<script src="/static/js/neon-demo.js"></script>
<script src="/static/js/echarts.min.js"></script>
<script>
    var chartDom = document.getElementById('main');
    var myChart = echarts.init(chartDom);
    var option;
    let dataAxis = {{ techologyRow | safe }};
    let data = {{ techologyCol | safe }};
    let yMax = 500;
    let dataShadow = [];
    for (let i = 0; i < data.length; i++) {
        dataShadow.push(yMax);
    }
    option = {
        title: {
            text: '市场技术排行 ',
        },
        toolbox: {
            show: true,
            feature: {
                dataView: {show: true, readOnly: false},
                restore: {show: true},
                saveAsImage: {show: true}
            }
        },
        xAxis: {
            data: dataAxis,
            axisLabel: {
                inside: true,
                color: '#fff'
            },
            axisTick: {
                show: false
            },
            axisLine: {
                show: false
            },
            z: 10
        },
        yAxis: {
            axisLine: {
                show: false
            },
            axisTick: {
                show: false
            },
            axisLabel: {
                color: '#999'
            }
        },
        dataZoom: [
            {
                type: 'inside'
            }
        ],
        series: [
            {
                type: 'bar',
                showBackground: true,
                itemStyle: {
                    color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                        {offset: 0, color: '#83bff6'},
                        {offset: 0.5, color: '#188df0'},
                        {offset: 1, color: '#188df0'}
                    ])
                },
                emphasis: {
                    itemStyle: {
                        color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                            {offset: 0, color: '#2378f7'},
                            {offset: 0.7, color: '#2378f7'},
                            {offset: 1, color: '#83bff6'}
                        ])
                    }
                },
                data: data,
                label: {
                    show: true,
                    position: 'top',
                    color: '#188df0',
                    fontSize: '12px',
                    formatter: (params) => {
                        return params.value[params.encode.x[0]]
                    }

                }
            }
        ]
    };
    const zoomSize = 6;
    myChart.on('click', function (params) {
        console.log(dataAxis[Math.max(params.dataIndex - zoomSize / 2, 0)]);
        myChart.dispatchAction({
            type: 'dataZoom',
            startValue: dataAxis[Math.max(params.dataIndex - zoomSize / 2, 0)],
            endValue:
                dataAxis[Math.min(params.dataIndex + zoomSize / 2, data.length - 1)]
        });
    });
    option && myChart.setOption(option);
</script>
<script>
    var chartDom = document.getElementById('mainTwo');
    var myChart = echarts.init(chartDom);
    var option;
    option = {
       tooltip: {
            trigger: 'item',
            formatter: '{b} : {c}'
        },
        toolbox: {
            show: true,
            feature: {
                mark: {show: true},
                dataView: {show: true, readOnly: false},
                restore: {show: true},
                saveAsImage: {show: true}
            }
        },
        legend: {
            top: '3%',
            x: 'left',
            y: 'top',
            orient: 'vartical',
            selectedMode: false
        },
        series: [
            {
                name: '企业融资情况',
                type: 'pie',
                radius: [50, 150],
                center: ['50%', '50%'],
                roseType: 'area',
                clockwise: true,
                itemStyle: {
                    borderRadius: 8
                },
                 label:{
                     fontSize: 15,
                     formatter:function(CompanyStuData){
	                  return `${CompanyStuData.name}
(${CompanyStuData.percent.toFixed(1)}%)`}
                },
                emphasis: {
                    label: {
                        fontSize: 20
                    }
                },
                data: {{ CompanyStuData | safe }}
            }
        ]
    };
    option && myChart.setOption(option);
</script>
</body>
</html>

5.6城市类型页面

在views,编写城市类型分析的代码

def address(request):
    uname = request.session['username']
    userInfo = User.objects.get(username=uname)
    defualtCity = '北京'
    if request.GET.get('city'):
        defualtCity = request.GET.get('city')
    hostCities = getAddress.getPage()
    salaryRow, salaryCol = getAddress.getSalaryData(defualtCity)
    companyPeoData = getAddress.companyPeoData(defualtCity)
    educationData = getAddress.getEduData(defualtCity)
    distData = getAddress.getDist(defualtCity)
    return render(request, 'address.html', {
        'userInfo': userInfo,
        'defualtCity': defualtCity,
        'hostCities': hostCities,
        'salaryRow': salaryRow,
        'salaryCol': salaryCol,
        'companyPeoData': companyPeoData,
        'educationData': educationData,
        'distData': distData,
    })

对个城市类型分析,写在/myapp/utils中的getAddress.py中,在views调用函数方法

from .getPublicData import *
from myapp.models import JobInfo
import json
def getPage():
    return City
​
​
def getSalaryData(city):
    jobs=JobInfo.objects.filter(address=city)
    salaries=[]
    for i in jobs:
        if i.pratice=='0':
            salaries.append(json.loads(i.salary)[1])
    salaryCol=[0 for x in range(len(salarylist))]
    for i in salaries:
        if i <1000:
            salaryCol[0] += 1
        else:
            s=i/1000
            if s < 10:
                salaryCol[0]+=1
            if s < 20:
                salaryCol[1]+=1
            if s < 30:
                salaryCol[2]+=1
            if s < 40:
                salaryCol[3]+=1
            else:
                salaryCol[4] += 1
    print(salaryCol)
    return salarylist,salaryCol
​
def companyPeoData(city):
    jobs = JobInfo.objects.filter(address=city)
    peoples=[]
    for i in jobs:
        peoples.append(json.loads(i.companyPeo)[1])
    peopleCol = [0 for x in range(len(companyPeo))]
    for p in peoples:
        if p<=20:
            peopleCol[0]+=1
        if p<=100:
            peopleCol[1]+=1
        if p<=500:
            peopleCol[2]+=1
        if p<=1000:
            peopleCol[3]+=1
        if p<10000:
            peopleCol[4]+=1
        else:
            peopleCol[5]+=1
    result=[]
    for index,item in enumerate(peopleCol):
        result.append({
            'name':companyPeo[index],
            'value':item
        })
    return  result
​
​
def getEduData(city):
    jobs = JobInfo.objects.filter(address=city)
    educationData= {}
    for job in jobs:
        if educationData.get(job.edu,-1)==-1:
            educationData[job.edu]=1
        else:
            educationData[job.edu] += 1
    result = []
    for k, v in educationData.items():
        result.append({
            'name': k,
            'value': v
        })
    return result
​
​
def getDist(city):
    jobs = JobInfo.objects.filter(address=city)
    distData = {}
    for job in jobs:
        if job.dist !='':
            if distData.get(job.dist,-1)==-1:
                distData[job.dist]=1
            else:
                distData[job.dist] += 1
    result = []
    for k, v in distData.items():
        result.append({
            'name': k,
            'value': v
        })
    return result

在/myapp/templates/下新建address.html页面,编写网页代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta name="description" content="Neon Admin Panel">
    <meta name="author" content="">
    <title>
        城市类型
    </title>
    <link rel="stylesheet" href="/static/css/jquery-ui-1.10.3.custom.min.css">
    <link rel="stylesheet" href="/static/css/entypo.css">
    <link rel="stylesheet" href="/static/css/css.css">
    <link rel="stylesheet" href="/static/css/bootstrap.css">
    <link rel="stylesheet" href="/static/css/neon-core.css">
    <link rel="stylesheet" href="/static/css/neon-theme.css">
    <link rel="stylesheet" href="/static/css/neon-forms.css">
    <link rel="stylesheet" href="/static/css/custom.css">
    <script src="/static/js/jquery-1.11.0.min.js"></script>
    <script src="/assets/js/ie8-responsive-file-warning.js"></script>
    <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
    <script src="https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js"></script>
</head>
<body class="page-body  page-left-in" data-url="http://neon.dev">
<div class="page-container">
    <div class="sidebar-menu">
        <header class="logo-env">
            <div class="logo">
                <a href="index.html">
                    <h3 style="color: #fff1f0;font-weight: bold;margin-top: 5px">岗位数据可视化</h3>
                </a>
            </div>
        </header>
        <div class="sidebar-user-info">
            <div class="sui-normal">
                <a href="#" class="user-link">
                    <img style="width: 95%;border-radius: 50%" src="/media/{{ userInfo.avatar }}" width="120" alt=""><br>

                    <span style="text-align: center;padding-top: 209px">欢迎回来,</span>
                    <strong style="text-align: center;margin-top: 5px">{{ userInfo.username }}</strong>
                </a>
            </div>
        </div>
        <ul id="main-menu" class="">
            <li>
                <a href="/myapp/home">
                    <i class="entypo-gauge"></i>
                    <span>首页</span>
                </a>
            </li>
            <li>
                <a href="#">
                    <i class="entypo-user"></i>
                    <span>个人中心</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/selfInfo">
                            <span>个人信息</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/changePW">
                            <span>修改密码</span>
                        </a>
                    </li>
                </ul>
            </li>

            <li>
                <a href="/myapp/tableData">
                    <i class="entypo-newspaper"></i>
                    <span>数据总览</span>
                </a>
            </li>
            <li class="opened active">
                <a href="#">
                    <i class="entypo-chart-bar"></i>
                    <span>可视化</span>
                </a>
                <ul>
                    <li>
                        <a href="/myapp/salary">
                            <i class="entypo-light-down"></i>
                            <span>薪资</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/company">
                            <i class="entypo-feather"></i>
                            <span>企业</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/companyTags">
                            <i class="entypo-lamp"></i>
                            <span>福利</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/edu">
                            <i class="entypo-graduation-cap"></i>
                            <span>学历分布</span>
                        </a>
                    </li>
                    <li>
                        <a href="/myapp/companyStatus">
                            <i class="entypo-network"></i>
                            <span>企业融资</span>
                        </a>
                    </li>
                    <li class="active">
                        <a href="/myapp/address">
                            <i class="entypo-rocket"></i>
                            <span>城市类型</span>
                        </a>
                    </li>
                </ul>
            </li>
        </ul>
    </div>
    <div class="main-content">
        <div class="row" style="display: flex">
            <div style="margin-left: auto" class="col-md-6 col-sm-4 clearfix hidden-xs">
                <ul class="list-inline links-list pull-right">
                    <li class="sep"></li>
                    <li>
                        <a href="/myapp/logout">
                            注销 <i class="entypo-logout right"></i>
                        </a>
                    </li>
                </ul>

            </div>

        </div>
        <hr>
        <ol class="breadcrumb bc-3">
            <li>
                <a href="#">
                    <i class="entypo-home"></i>
                    可视化图表
                </a>
            </li>
            <li>
                <strong>城市类型</strong>
            </li>
        </ol>
        <h2>城市类型</h2>
        <br>
        <div class="row">
            <div class="col-md-6">
                <div class="panel panel-warning" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">选择输入框</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1"
                               class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <form action="/myapp/address/" method="get">
                            <div class="col-md-4">
                                <select name="city" class="form-control">
                                    {% for i in hostCities %}
                                        {% if i == defualtCity %}
                                            <option selected value="{{ i }}">{{ i }}</option>
                                        {% else %}
                                            <option value="{{ i }}">{{ i }}</option>
                                        {% endif %}
                                    {% endfor %}
                                </select>
                            </div>
                            <button type="submit" class="btn btn-info">提交</button>
                        </form>
                    </div>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-md-6">
                <div class="panel panel-success" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">薪资分布情况</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div id="main" style="width: 100%;height: 450px">
                       </div>
                    </div>
                </div>
            </div>
            <div class="col-md-6">
                <div class="panel panel-success" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">公司分布</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i  class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div id="mainTwo" style="width: 100%;height: 450px">
                        </div>
                    </div>
                </div>
            </div>
        </div>
        <div class="row">
            <div class="col-md-6">
                <div class="panel panel-success" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">学历要求</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i  class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div id="mainThree" style="width: 100%;height: 450px">
                        </div>
                    </div>
                </div>
            </div>
            <div class="col-md-6">
                <div class="panel panel-success" data-collapsed="0">
                    <div class="panel-heading">
                        <div class="panel-title">行政区数量</div>
                        <div class="panel-options">
                            <a href="#sample-modal" data-toggle="modal" data-target="#sample-modal-dialog-1" class="bg"><i  class="entypo-cog"></i></a>
                            <a href="#" data-rel="collapse"><i class="entypo-down-open"></i></a>
                            <a href="#" data-rel="reload"><i class="entypo-arrows-ccw"></i></a>
                            <a href="#" data-rel="close"><i class="entypo-cancel"></i></a>
                        </div>
                    </div>
                    <div class="panel-body">
                        <div id="mainFour" style="width: 100%;height: 450px">
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>
<link rel="stylesheet" href="/static/css/jquery-jvectormap-1.2.2.css">
<link rel="stylesheet" href="/static/css/rickshaw.min.css">
<script src="/static/js/fileinput.js"></script>
<script src="/static/js/main-gsap.js"></script>
<script src="/static/js/jquery-ui-1.10.3.minimal.min.js"></script>
<script src="/static/js/bootstrap.js"></script>
<script src="/static/js/joinable.js"></script>
<script src="/static/js/resizeable.js"></script>
<script src="/static/js/neon-api.js"></script>
<script src="/static/js/jquery-jvectormap-1.2.2.min.js"></script>
<script src="/static/js/jquery-jvectormap-europe-merc-en.js"></script>
<script src="/static/js/jquery-jvectormap-world-mill-en.js"></script>
<script src="/static/js/jquery.sparkline.min.js"></script>
<script src="/static/js/d3.v3.js"></script>
<script src="/static/js/rickshaw.min.js"></script>
<script src="/static/js/neon-chat.js"></script>
<script src="/static/js/neon-custom.js"></script>
<script src="/static/js/neon-demo.js"></script>
<script src="/static/js/echarts.min.js"></script>
<script>
    var chartDom = document.getElementById('main');
    var myChart = echarts.init(chartDom);
    var option;
    option = {
        title: {},
        tooltip: {
            trigger: 'axis',
            axisPointer: {
                lineStyle: {
                    width: 3,
                    color: '#019688'
                }
            }
        },
        gird: {
            left: '4%',
            right: '3%',
            bottom: '3%',
            containLabel: true,
        },
        toolbox: {
            show: true,
            feature: {

                dataView: {show: true, readOnly: false},

                restore: {show: true},
                saveAsImage: {show: true}

            }
        },
        legend: {},
        grid: {
            left: '3%',
            right: '4%',
            bottom: '3%',
            containLabel: true
        },
        xAxis: [
            {
                type: 'category',
                boundaryGap: false,
                data: {{ salaryRow | safe }}
            }
        ],
        yAxis: [
            {
                type: 'value',

                max: 1000
            }
        ],
        series: [
            {
                name: '个数',
                type: 'line',
                stack: 'Total',
                smooth: true,
                areaStyle: {},
                emphasis: {
                    focus: 'series'
                },
                data: {{ salaryCol | safe }}
            },
        ]
    };
    option && myChart.setOption(option);
</script>
<script>
    var chartDom = document.getElementById('mainTwo');
    var myChart = echarts.init(chartDom);
    var option;
    const piePatternSrc =        '';
    const bgPatternSrc =
        '';
    const piePatternImg = new Image();
    piePatternImg.src = piePatternSrc;
    const bgPatternImg = new Image();
    bgPatternImg.src = bgPatternSrc;
    option = {
        backgroundColor: {
            image: bgPatternImg,
            repeat: 'repeat'
        },
        title: {
            text: '',
            textStyle: {
                color: '#235894'
            },
            padding: [60, 0, 0, 30]
        },
        tooltip: {},
        toolbox: {
            orient: 'vertical',
            feature: {
                dataView: {readOnly: false},
                restore: {},
                saveAsImage: {}
            }
        },
        legend: {},
        series: [
            {
                name: '公司人数区间',
                type: 'pie',
                top: '5%',
                selectedMode: 'single',
                selectedOffset: 20,
                clockwise: true,
                label: {
                    fontSize: 15,
                    color: '#235894',
                    formatter: function (companyPeoData) {
                        return `${companyPeoData.name}
(${companyPeoData.percent.toFixed(1)}%)`
                    }
                },
                labelLine: {
                    lineStyle: {
                        color: '#235894'
                    }
                },
                data: {{ companyPeoData | safe }},
                itemStyle: {
                    opacity: 0.5,
                    color: {
                        image: piePatternImg,
                        repeat: 'repeat'
                    },
                    borderWidth: 3,
                    borderColor: '#235894'
                }
            }
        ]
    };
   option && myChart.setOption(option);
</script>
<script>
    var chartDom = document.getElementById('mainThree');
    var myChart = echarts.init(chartDom);
    var option;
    option = {
        title: {
            text: ''
        },
        tooltip: {
            trigger: 'item',
            formatter: '{a} <br/>{b} : {c}人数'
        },
        toolbox: {
            feature: {
                dataView: {readOnly: false},
                restore: {},
                saveAsImage: {}
            }
        },
        legend: {
            top: '3%',
            x: 'left',
            y: 'top',
            orient: 'vartical',
            selectedMode: false
        },
        series: [
            {
                name: 'Funnel',
                type: 'funnel',
                left: '10%',
                top: 60,
                bottom: 60,
                width: '80%',
                minSize: '0%',
                maxSize: '100%',
                sort: 'descending',
                gap: 2,
                label: {
                    show: true,
                    position: 'inside'
                },
                labelLine: {
                    length: 10,
                    lineStyle: {
                        width: 1,
                        type: 'solid'
                    }
                },
                itemStyle: {
                    borderColor: '#fff',
                    borderWidth: 1
                },
                emphasis: {
                    label: {
                        fontSize: 20
                    }
                },
                data: {{ educationData | safe }}
            }
        ]
    };
    option && myChart.setOption(option);
</script>
<script>
    var chartDom = document.getElementById('mainFour');
    var myChart = echarts.init(chartDom);
    var option;
    option = {
        tooltip: {
            trigger: 'item'
        },
        legend: {
            top: '5%',
            left: 'center'
        },
        toolbox: {
            feature: {
                dataView: {readOnly: false},
                restore: {},
                saveAsImage: {}
            }
        },
        series: [
            {
                name: 'Access From',
                type: 'pie',
                radius: ['40%', '70%'],
                avoidLabelOverlap: false,
                itemStyle: {
                    borderRadius: 10,
                    borderColor: '#fff',
                    borderWidth: 2
                },
                label: {
                    show: false,
                    position: 'center',
                    formatter: function (distData) {
                        return `${distData.name}
(${distData.percent.toFixed(1)}%)`
                    }
                },
                emphasis: {
                    label: {
                        show: true,
                        fontSize: 40,
                        fontWeight: 'bold'
                    }
                },
                labelLine: {
                    show: false
                },
                data: {{ distData | safe }}
            }
        ]
    };
    option && myChart.setOption(option);
</script>
</body>
</html>

6.拦截器

在/middleware下,编写useInfoMid.py代码。首先判断请求路径是否为/myapp/login/或/myapp/register/或以/admin开头的路径,如果是其中之一,则直接返回None,不进行后续处理。如果不是这些路径,则判断用户是否已经登录,如果没有登录,则重定向到登录页面。

from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import render, redirect
import re

class UserMW(MiddlewareMixin):
    def process_request(self, request):
        path = request.path_info
        if path == '/myapp/login/' or path == '/myapp/register/' or re.search('^/admin.*',path):
            return None
        else:
            if not request.session.get('username'):
                return redirect('login')
        return None

    def process_view(self, request, callback, callback_args, callback_kwargs):
        return None

    def process_response(self, request, response):
        return response

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清风--明月

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值