# classtop_urls.py
# ————————64PerfectCRM实现CRM课程排名详情————————
from django.conf.urls import url
from bpm.coursetop import coursetop_views
urlpatterns = [
url( r'^coursetop_details/(\d+)/$', coursetop_views.coursetop_details, name="coursetop_details" ), # 课程排名详情 # ————————65PerfectCRM实现CRM课程分数排名————————
url( r'^coursetop_score/(\d+)/$', coursetop_views.coursetop_score, name="coursetop_score" ), # 班级分数排行
# ————————65PerfectCRM实现CRM课程分数排名———————— ]
# ————————64PerfectCRM实现CRM课程排名详情————————

# classtop_urls.py

 # coursetop_views.py
# ————————64PerfectCRM实现CRM课程排名详情————————
#————班级学生详情——#计算#{学员ID:分数}——#计算 #{学员ID: [分数, 排名] }————#
#班级学生详情#计算#{学员ID:分数}
from django.db.models import Sum #返回数组中所有值的和
def get_course_grades(class_obj):#返回整个班级的成绩
c=models.StudyRecord.objects.filter(course_record__from_class=class_obj).values_list('student')
a=Sum('score')#Sum返回数组中所有值的和 #学习成绩
e=c.annotate(a) #annotate数据库的数据聚合函数
class_grade_dic=dict(e)#{1: 285, 16: 190}#{学员ID:分数}
print( '全班成绩:', class_grade_dic)
return class_grade_dic #as class_grade_dic #班级学生详情#计算 #{学员ID: [分数, 排名] }
def get_course_ranking(class_grade_dic):#返回整个班级的排名数据
ranking_list = sorted(class_grade_dic.items(),key=lambda x:x[1],reverse=True)#进行排序后的列表#以第2个参数对比#倒序
print('成绩排序:',ranking_list)
ranking_dic = {}
for item in ranking_list:
ranking_dic[item[0]] = [item[1], ranking_list.index(item)+1] #循环添加 排名数 到 排序后的列表
print( '全班排名:', ranking_dic)#{1: [285, 1], 10: [280, 2], }#{学员ID: [分数, 排名] }
return ranking_dic
#————班级学生详情——#计算#{学员ID:分数}——#计算 #{学员ID: [分数, 排名] }————# from django.contrib.auth.decorators import login_required # 登陆后页面才能访问
from django.shortcuts import render #页面返回
from crm import models #数据库
#班级学生详情
@login_required # 登陆后页面才能访问
def coursetop_details(request,class_id):
classes_obj = models.ClassList.objects.get(id=class_id)#通过ID获取02班级表
enrollmentlist=classes_obj.enrollment_set.all()#通过班级ID,获取06学员报名信息表 class_grade_dic=get_course_grades(classes_obj.id)#{学员ID:分数} #全班成绩 # coursetop_tags.py 根据id 找对应的分数
ranking_dic=get_course_ranking(class_grade_dic)#{学员ID: [分数, 排名] } #全班排名 # coursetop_tags.py 根据id 找对应的排名 return render(request,'bpm_coursetop/coursetop_details.html',locals())
# ————————64PerfectCRM实现CRM课程排名详情———————— # ————————65PerfectCRM实现CRM课程分数排名————————
#———— 班级学生详情——#计算 #{排名: (ID, 分数)}#排名查名字————#
def get_ranking_name(class_grade_dic):
lists=[]
ranking_list = sorted(class_grade_dic.items(),key=lambda x:x[1],reverse=True)#进行排序后的列表#以第2个参数对比#倒序
#ranking_list [(1, 285), (10, 280)] #按分高排序的ID顺序
for item in ranking_list:
temp={}
temp[ranking_list.index(item) + 1] = item # 循环添加 排名数 到 排序后的列表
lists.append(temp)
print( '排名查名字:', lists )#[{1: (1, 285)}, {2: (10, 280)}]#[{排名: (学员ID, 分数)}]
return lists
#———— 班级学生详情——#计算 #{排名: (ID, 分数)}#排名查名字————# #班级学生详情#全班成绩排名 #通过#{排名: (ID, 分数)}#排名查名字
@login_required # 登陆后页面才能访问
def coursetop_score(request,class_id):
classes_obj = models.ClassList.objects.get(id=class_id)#通过ID获取02班级表
class_grade_dic=get_course_grades(classes_obj.id)#{学员ID:分数} #全班成绩
lists=get_ranking_name(class_grade_dic)#计算#[{排名: (学员ID, 分数)}] #按分高排序的ID顺序
return render(request,'bpm_coursetop/coursetop_score.html',locals()) # ————————65PerfectCRM实现CRM课程分数排名————————

# coursetop_views.py

 # coursetop_tags.py
# ————————64PerfectCRM实现CRM课程排名详情————————
from crm import models
from django import template
register = template.Library() @register.simple_tag
def fetch_stu_course_score(class_grade_dic, enroll_obj_id ): #获取 学员 课程 分数
score=class_grade_dic.get(enroll_obj_id) #根据 id 找对应的分数
# print('#{学员ID:分数} #全班成绩',score)
return score @register.simple_tag
def get_stu_grade_ranking(course_ranking_dic,enroll_obj_id):#得到 学员 班级 排名
score_top = course_ranking_dic.get(enroll_obj_id) #根据id 找对应的排名
if score_top:
# print( '#{学员ID: [分数, 排名] } #全班排名:', score_top[1] )
return score_top[1] @register.simple_tag
def get_already_homework(enroll_obj_id): #获得已交作业
score_list=models.StudyRecord.objects.select_related().filter(student=enroll_obj_id).values_list('score')#根据09学习纪录的ID #获取学习成绩列表
number=0
for score in score_list:
if score!= (0,) :
number += 1
# print('已交作业次数',number)
return number @register.simple_tag
def get_stu_attendance(enroll_obj_id): #获得学员出勤次数
attendance_list=models.StudyRecord.objects.select_related().filter(student=enroll_obj_id).values_list('attendance')
number=0
for attendance in attendance_list:
if attendance == (0,) :
number += 1
# print('获得点名出勤',number)
return number @register.simple_tag
def get_stu_late(enroll_obj_id): #获得学员迟到次数
attendance_list=models.StudyRecord.objects.select_related().filter(student=enroll_obj_id).values_list('attendance')
number=0
for attendance in attendance_list:
if attendance == (1,) :
number += 1
# print('获得点名迟到',number)
return number @register.simple_tag
def get_stu_absenteeism(enroll_obj_id): #获得学员缺勤次数
attendance_list=models.StudyRecord.objects.select_related().filter(student=enroll_obj_id).values_list('attendance')
number=0
for attendance in attendance_list:
if attendance == (2,) :
number += 1
# print('获得点名缺勤',number)
return number @register.simple_tag
def get_stu_early(enroll_obj_id): #获得学员早退次数
attendance_list=models.StudyRecord.objects.select_related().filter(student=enroll_obj_id).values_list('attendance')
number=0
for attendance in attendance_list:
if attendance == (3,) :
number += 1
# print('获得点名早退',number)
return number
# ————————64PerfectCRM实现CRM课程排名详情———————— # ————————65PerfectCRM实现CRM课程分数排名————————
@register.simple_tag
def id_enrollment(enroll_obj):#ID查姓名
enrollment = models.Enrollment.objects.filter(id=enroll_obj).first()#通过学员ID查06学员报名信息表
return enrollment #06学员报名信息表
# ————————65PerfectCRM实现CRM课程分数排名————————

# coursetop_tags.py

 {#coursetop_score.html#}
{## ————————65PerfectCRM实现CRM课程分数排名————————#}
{% extends 'bpm_master/bpm_sample.html' %}
{% load coursetop_tags %}
{% block right-container-content %} {#自定义内容开始 右边页面内容#}
<div class="panel-default">
<div class="panel-default">
<div class="panel-body">
<h4>当前用户: {{ request.user }} | 讲师名字:{{ request.user.stu_account.name }} |
讲师QQ:{{ request.user.stu_account }} </h4>
<ol class="breadcrumb">
<li><a href="{% url 'teacher_class' %}">我的班级</a></li>
<li><a href="{% url 'teacher_class_detail' classes_obj.id %}">{{ classes_obj }}</a></li>
<li><a href="{% url 'coursetop_score' classes_obj.id %}">分数排名</a></li>
</ol>
<table class="table table-striped table-responsive">
<thead>
<tr>
<th><a href="{% url 'coursetop_details' classes_obj.id %}">学员ID</a></th>
<th><a target="_blank" href="/king_admin/crm/enrollment/?enrolled_class={{ class_id }}">学员姓名</a>
</th>
<th>学员QQ</th>
<th>报名日期</th>
<th>课程成绩</th>
<th>班级排名</th>
<th>已交作业</th>
<th>出勤次数</th>
<th>迟到次数</th>
<th>缺勤次数</th>
<th>早退次数</th>
</tr>
</thead> <tbody>
{% for enroll_objs in lists %}
{% for top,enroll_obj in enroll_objs.items %}{#分离提取K,V#[{排名: (学员ID, 分数)}]#}
{% id_enrollment enroll_obj.0 as enrollment %}{#enroll_obj.0 #学员ID#}{#通过学员ID查06学员报名信息表#}
<tr>
<td>{{ enroll_obj.0 }}</td>
{#学员ID#}
<td>{{ enrollment.customer.name }}</td>
{#学员姓名#}
<td>{{ enrollment.customer.qq }}</td>
{#学员QQ#}
<td>{{ enrollment.date }}</td>
{#报名日期#}
<td style="color: #ff0f00"> {{ enroll_obj.1 }}{#课程成绩#} </td>
<td style="color: #ff0f00">
{{ top }}{#班级排名#}
</td>
<td>{% get_already_homework enroll_obj.0 %}</td>
{#已交作业#}
<td>
{% get_stu_attendance enroll_obj.0 %}{#出勤次数#}
</td>
<td>
{% get_stu_late enroll_obj.0 %}{#迟到次数#}
</td>
<td>
{% get_stu_absenteeism enroll_obj.0 %}{#缺勤次数#}
</td>
<td>
{% get_stu_early enroll_obj.0 %}{#早退次数#}
</td>
</tr>
{% endfor %}
{% endfor %}
</tbody>
</table>
</div>
</div>
</div>
{% endblock %}
{## ————————65PerfectCRM实现CRM课程分数排名————————#}

{#coursetop_score.html#}

 {#coursetop_details.html#}
{## ————————64PerfectCRM实现CRM课程排名详情————————#}
{% extends 'bpm_master/bpm_sample.html' %}
{% load coursetop_tags %} {#计算课程排名#}
{% block right-container-content %} {#自定义内容开始 右边页面内容#}
<div class="panel-default">
<div class="panel-default">
<div class="panel-body">
<h4>当前用户: {{ request.user }} | 讲师名字:{{ request.user.stu_account.name }} |
讲师QQ:{{ request.user.stu_account }} </h4>
<ol class="breadcrumb">
<li><a href="{% url 'teacher_class' %}">我的班级</a></li>
<li><a href="{% url 'teacher_class_detail' classes_obj.id %}">{{ classes_obj }}</a></li>
<li><a href="{% url 'coursetop_details' classes_obj.id %}">课程排行</a></li>
</ol>
<table class="table table-striped table-responsive">
<thead>
<tr>
<th>学员ID</th>
<th><a target="_blank" href="/king_admin/crm/enrollment/?enrolled_class={{ class_id }}">学员姓名</a>
</th>
<th>学员QQ</th>
<th>报名日期</th>
<th>
{## ————————65PerfectCRM实现CRM课程分数排名————————#}
<a href="{% url 'coursetop_score' classes_obj.id %}">
{## ————————65PerfectCRM实现CRM课程分数排名————————#}
课程成绩
</a>
</th>
<th>
{## ————————65PerfectCRM实现CRM课程分数排名————————#}
<a href="{% url 'coursetop_score' classes_obj.id %}">
{## ————————65PerfectCRM实现CRM课程分数排名————————#}
班级排名
</a>
</th>
<th>已交作业</th>
<th>出勤次数</th>
<th>迟到次数</th>
<th>缺勤次数</th>
<th>早退次数</th>
</tr>
</thead> <tbody>
{% for enroll_obj in enrollmentlist %}
<tr>
<td style="color: #ff0f00">{{ enroll_obj.id }}</td>
{# 学员id#}
<td>{{ enroll_obj.customer.name }}</td>
{# 学员姓名#}
<td>{{ enroll_obj.customer.qq }}</td>
{# 学员QQ#}
<td>{{ enroll_obj.date }}</td>
{# 报名日期#}
<td>
{% fetch_stu_course_score class_grade_dic enroll_obj.id %} {# 得到 学员 课程 分数#}
</td>
<td>
{% get_stu_grade_ranking ranking_dic enroll_obj.id %} {# 得到 学员 课程 排名#}
</td>
<td>
{% get_already_homework enroll_obj.id %}{# 已交作业#}
</td>
<td>
{% get_stu_attendance enroll_obj.id %} {# 得到 学员出勤次数#}
</td>
<td>
{% get_stu_late enroll_obj.id %} {# 得到 学员出勤次数#}
</td>
<td>
{% get_stu_absenteeism enroll_obj.id %} {# 得到 学员出勤次数#}
</td>
<td>
{% get_stu_early enroll_obj.id %} {# 得到 学员早退次数#}
</td>
</tr>
{% endfor %}
</tbody>
</table>
</div>
</div>
</div>
{% endblock %}
{## ————————64PerfectCRM实现CRM课程排名详情————————#}

{#coursetop_details.html#}

Django项目:CRM(客户关系管理系统)--75--65PerfectCRM实现CRM课程分数排名的更多相关文章

  1. Django CRM客户关系管理系统

    CRM需求分析 随着信息化时代带来的科技创新,CRM客户关系管理系统带来的效益在已经成为很多企业提高竞争优势的一分部,CRM客户关系管理系统将企业管理和客户关系管理集成到统一的平台,其系统功能主要体现 ...

  2. Django项目:CRM(客户关系管理系统)--84--74PerfectCRM实现CRM权限和权限组限制访问URL

    #models.py # ————————01PerfectCRM基本配置ADMIN———————— from django.db import models # Create your models ...

  3. Django项目:CRM(客户关系管理系统)--70--60PerfectCRM实现CRM学生上课记录

    #urls.py """PerfectCRM URL Configuration The `urlpatterns` list routes URLs to views. ...

  4. Django项目:CRM(客户关系管理系统)--80--70PerfectCRM实现CRM业务流程(bpm)课程排行分页

    # coursetop_views.py # ————————64PerfectCRM实现CRM课程排名详情———————— #————班级学生详情——#计算#{学员ID:分数}——#计算 #{学员I ...

  5. Django项目:CRM(客户关系管理系统)--77--67PerfectCRM实现CRM课程出勤排名

    # classtop_urls.py # ————————64PerfectCRM实现CRM课程排名详情———————— from django.conf.urls import url from b ...

  6. Django项目:CRM(客户关系管理系统)--76--66PerfectCRM实现CRM课程作业排名

    # classtop_urls.py # ————————64PerfectCRM实现CRM课程排名详情———————— from django.conf.urls import url from b ...

  7. Django项目:CRM(客户关系管理系统)--74--64PerfectCRM实现CRM课程排名详情

    #urls.py """PerfectCRM URL Configuration The `urlpatterns` list routes URLs to views. ...

  8. Django项目:CRM(客户关系管理系统)--72--62PerfectCRM实现CRM讲师讲课记录

    #urls.py """PerfectCRM URL Configuration The `urlpatterns` list routes URLs to views. ...

  9. CRM客户关系管理系统-需求概设和详设

    大概设计 大概设计就是对需求进行一个整体性分析,把需要实现的功能都列出来,对于客户关系管理系统,我们需要从角色出发,从而确定有哪些需求,最好是画个思维导图 首先我们是为培训学校这么一个场景来开发的,所 ...

随机推荐

  1. day14 python02---字符串

    day02 数字相关的转换 bin() 2进制oct() 8进制hex() 16进制 字符串 定义:它是一个有序的字符的集合,用于存储和表示基本的文本信息,‘’或“”或‘’‘ ’‘’中间包含的内容称之 ...

  2. 「题解」:$e$

    问题 B: $e$ 时间限制: 2 Sec  内存限制: 512 MB 题面 题面谢绝公开. 题解 话说一天考两个主席树这回事…… 正解可以叫树上主席树??(脸哥说也叫主席树上树???) 对于树上的每 ...

  3. hibernate_02_hibernate的入门

    1.什么是Hibernate框架? Hibernate是一种ORM框架,全称为 Object_Relative DateBase-Mapping,在Java对象与关系数据库之间建立某种映射,以实现直接 ...

  4. [JZOJ 5788] 餐馆

    思路: 考虑树形dp. 我们设\(dp[i][j][0/1]\)表示在\(i\)为根的子树中花费\(j\)单位时间,最终回到/不必回到\(i\)的最大收益. 转移三种: \(dp[x][j][0] = ...

  5. 谈谈域名DNS的缓存问题

    可以从很多地方看到,许多刚开始做站的朋友,对域名设置方面的知识原理一知半解,以至于为了某些测试需要,经常对域名解析大动干戈.今天改个A记录,明天又换个NS.又或者,在迁移域名,迁移网站的时候的时候由于 ...

  6. Day 8 : Python 文档操作

    Python 文件的操作方法: 打开文件 f = open('test','r',encoding='utf-8') #f :文件句柄 #test:文件绝对路径 #r:打开方式 #encoding 打 ...

  7. HTML5 新模块元素兼容问题

    新增块元素默认样式 下列HTML5新模块元素在IE8.9版本浏览器中没有被定义默认样式.为解决该问题,给下列元素添加“block”显示属性. 代码: article, aside, details, ...

  8. POJ 2187 /// 凸包入门 旋转卡壳

    题目大意: 求最远点对距离 求凸包上的最远点对 挑战263页 #include <cstdio> #include <string.h> #include <algori ...

  9. java笔试之尼科彻斯定理

    验证尼科彻斯定理,即:任何一个整数m的立方都可以写成m个连续奇数之和. 例如: 1^3=1 2^3=3+5 3^3=7+9+11 4^3=13+15+17+19 这题也可以用数学公式推理,首项m*(m ...

  10. linux常用软连接使用ln -s

    [软连接]另外一种连接称之为符号连接(Symbolic Link),也叫软连接.软链接文件有类似于Windows的快捷方式.它实际上是一个特殊的文件.在符号连接中,文件实际上是一个文本文件,其中包含的 ...