Python CRM项目一
开发环境:
- 语言Python3.X以上
- MTV WEB框架 Django
- 前端框架 jQuery+bootstrap
- 数据库 MySQL
运行环境
- 安装Python3.x
- 安装Django
- 除IE8以上的浏览器
项目需求:重写Django Admin的功能,实现对表动态的增删改查,实现权限的动态分配,实现自定义Action,等一系列组件扩展功能
项目功能图:

项目表UML表关系图

models.py表关系创建
from django.db import models
from django.contrib.auth.models import User
# Create your models here.
class Customer(models.Model):
'''客户信息表'''
name = models.CharField(max_length=32,null=True,blank=True)
qq = models.CharField(max_length=64,unique=True)
qq_name = models.CharField(max_length=64,null=True,blank=True)
phone = models.CharField(max_length=64,null=True,blank=True)
source_choices = ((0,'转介绍'),(1,'QQ群'),(2,'官网'),(3,'百度推广'),(4,'51cto'),(5,'知乎推荐'),(6,'市场推广'))
source = models.SmallIntegerField(choices=source_choices)
referral_from = models.CharField(verbose_name='转介绍人QQ',max_length=64,null=True,blank=True)
consult_course = models.ForeignKey('Course',verbose_name='咨询课程')
content = models.TextField(verbose_name='咨询详情')
consultant = models.ForeignKey('UserProfile',verbose_name='销售')
tags = models.ManyToManyField('Tag',blank=True,null=True);
memo = models.TextField(blank=True,null=True)
status_choice = (('signed','已报名'),('unregistered','未报名'))
status = models.CharField(max_length=64,choices=status_choice,default='unregistered',verbose_name='客户状态')
date = models.DateTimeField(auto_now_add=True) class Meta:
verbose_name_plural = '客户' def __str__(self):
return self.name class CustomerFollowUp(models.Model):
'''客户跟进表'''
customer = models.ForeignKey('Customer')
content = models.TextField(verbose_name='跟进内容')
consultant = models.ForeignKey('UserProfile')
intention_choices = ((0,'2周内报名'),(1,'1个月报名'),(2,'近期无报名计划'),(3,'已在其他机构报名'),(4,'已报名'),(5,'已拉黑'))
intention = models.SmallIntegerField(choices=intention_choices)
date = models.DateTimeField(auto_now_add=True) def __str__(self):
return '%s %s' % (self.customer.qq, self.intention) class Meta:
verbose_name_plural = '客户跟进记录' class Course(models.Model):
'''课程表'''
name = models.CharField(max_length=128,unique=True)
price = models.PositiveSmallIntegerField()
period = models.PositiveSmallIntegerField(verbose_name='周期(月)')
outline = models.TextField() def __str__(self):
return self.name class Meta:
verbose_name_plural = '课程' class Branch(models.Model):
'''校区表'''
name = models.CharField(max_length=128,unique=True)
addr = models.CharField(max_length=512) def __str__(self):
return self.name class Meta:
verbose_name_plural = '校区' class ClassList(models.Model):
'''班级表'''
branch = models.ForeignKey('Branch',verbose_name='分校')
course = models.ForeignKey('Course')
semester = models.PositiveSmallIntegerField(verbose_name='学期')
teachers = models.ManyToManyField('UserProfile')
class_type_choice = ((0,'面授班(脱产)'),(1,'面授班(周末)'),(2,'网络班'))
class_type = models.SmallIntegerField(choices=class_type_choice)
start_date = models.DateField(verbose_name='开班日期')
end_date = models.DateField(verbose_name='结业日期',blank=True,null=True) def __str__(self):
return '%s %s %s' % (self.branch, self.course, self.semester) class Meta:
unique_together = ('branch', 'course', 'semester')
verbose_name_plural = '班级' class CourseRecord(models.Model):
'''上课记录表'''
from_class = models.ForeignKey('ClassList',verbose_name='班级')
day_num = models.PositiveSmallIntegerField(verbose_name='第几节(天)')
teacher = models.ForeignKey('UserProfile')
has_homework = models.BooleanField(default=True)
homework_title = models.CharField(max_length=256,blank=True,null=True)
homework_content = models.TextField(blank=True,null=True)
outline = models.TextField(verbose_name='本节课大纲')
date = models.DateTimeField(auto_now_add=True) def __str__(self):
return '%s %s' % (self.from_class, self.day_num) class Meta:
unique_together = ('from_class', 'day_num')
verbose_name_plural = '上课记录' class StudyRecord(models.Model):
'''学习记录表'''
student = models.ForeignKey('Enrollment')
course_record = models.ForeignKey('CourseRecord')
attendance_choice = ((0,'已签到'),(1,'迟到'),(2,'缺勤'),(3,'早退'))
attendance = models.SmallIntegerField(choices=attendance_choice,default=0)
score_choices = ((100,'A+'),(90,'A'),(85,'B+'),(80,'B'),(75,'B-'),(70,'C+'),(60,'C'),(40,'C-'),(-50,'D'),(-100,'COPY'),(0,'N/A'))
score = models.SmallIntegerField(choices=score_choices)
memo = models.TextField(blank=True,null=True)
date = models.DateTimeField(auto_now_add=True) def __str__(self):
return '%s %s %s' % (self.student, self.course_record, self.score) class Meta:
unique_together = ('student', 'course_record')
verbose_name_plural = '学习记录' class Enrollment(models.Model):
'''学生报名表(学生报名信息,合同,入学日期,所报班级)'''
customer = models.ForeignKey('Customer')
enrolled_class = models.ForeignKey('ClassList',verbose_name='所报班级')
consultant = models.ForeignKey('UserProfile',verbose_name='课程顾问')
contact_agreed = models.BooleanField(default=False,verbose_name='学生已同意合同条款')
contact_approved = models.BooleanField(default=False,verbose_name='合同已审核')
date = models.DateTimeField(auto_now_add=True) def __str__(self):
return '%s %s' % (self.customer, self.enrolled_class) class Meta:
unique_together = ('customer', 'enrolled_class')
verbose_name_plural = '报名' class Payment(models.Model):
'''缴费记录'''
customer = models.ForeignKey('Customer')
course = models.ForeignKey('Course')
amount = models.PositiveIntegerField(verbose_name='数额',default=500)
consultant = models.ForeignKey('UserProfile')
date = models.DateTimeField(auto_now_add=True) def __str__(self):
return '%s %s' % (self.customer, self.amount) class Meta:
verbose_name_plural = '缴费记录' class UserProfile(models.Model):
'''账号表'''
user = models.OneToOneField(User)
name = models.CharField(max_length=32)
roles = models.ManyToManyField('Role',blank=True,null=True) def __str__(self):
return self.name class Role(models.Model):
'''角色表'''
name = models.CharField(max_length=64,unique=True) def __str__(self):
return self.name class Meta:
verbose_name_plural = '角色' class Tag(models.Model):
'''标签备注'''
name = models.CharField(max_length=64,unique=True) def __str__(self):
return self.name
class Meta:
verbose_name_plural = '标签'
在Settings文件中配置静态文件路径
STATIC_URL = '/static/'
STATICFILES_DIRS =(
os.path.join(BASE_DIR,'static'),
)
更改默认的数据库
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'prefect_crm',
'USER': 'root',
'PASSWORD': 'oldboy',
'HOST': '127.0.0.1',
'PORT': ''
}
}
在app下的__init__.py中插入
import pymysql
pymysql.install_as_MySQLdb()
Python CRM项目一的更多相关文章
- Python CRM项目二
一.准备工作 如果没有配置基本的项目,请参考 http://www.cnblogs.com/luhuajun/p/7771196.html 当我们配置完成后首先准备我们的app 创建2个app分别对应 ...
- Python CRM项目八
自定义用户认证 目的:实现Django自定义的认证系统,在生产环境都是根据此代码进行定制的 步骤: 1.在settings文件中配置要使用的类 #命名规则 app名称.类名 AUTH_USER_MOD ...
- Python CRM项目三
1.分页: 分页使用Django内置的分页模块来实现 官方的分页案例 from django.core.paginator import Paginator, EmptyPage, PageNotAn ...
- Python CRM项目七
仿照Django Admin实现对readonly的字段进行设置 功能点: 1.页面不可进行更改 2.如果改变html代码中的值,则需要进行后端的数据库数据校验 3.可以对某些字段进行自定制校验规则 ...
- Python CRM项目六
自定义Django Admin的action 在Django Admin中,可以通过action来自定义一些操作,其中默认的action的功能是选中多条数据来进行删除操作 我们在king_admin中 ...
- Python CRM项目四
实现Django Admin的多对多的复选框效果 效果:左边显示的是未选中的字段,右边显示的是已选中的字段,两边点击的标签可以互相更换 首先在king_admin.py中增加filter_horizo ...
- CRM项目总结
CRM项目总结 一:开发背景 在公司日益扩大的过程中,不可避免的会伴随着更多问题出现. 对外 : 如何更好的管理客户与公司的关系?如何更及时的了解客户日益发展的需求变 ...
- CRM项目之RBAC权限组件-day26
写在前面 上课第26天,打卡: 世间安得双全法 不负如来不负卿 s17day26 CRM项目 项目概要:XX公司CRM - 权限管理,公共组件,app ***** - 熟悉增删改查,Low *** - ...
- crm项目整理
crm项目整理 一.开发背景 由于公司人员的增多,原来通过excel表格存取方式过于繁琐,而且对于公司人员的调配和绩效考核等不能做到精确处理,所以开发crm系统,开始开发只是针对销售人员和客户,后 ...
随机推荐
- Linux中组 与 用户的管理
在linux中建立组的指令是 groupadd 组名 相应的,删除组的指令: groupdel 组名 查看自己用户的组: groups 一个用户可以在多个组里面,用这个命令可以将用户添加到组: add ...
- tomcat管理界面登录无法进入
问题: 在打开tomcat界面之后,点击Manger App准备进入管理界面,路径:http://localhost:8080/manager/html. 输入正确的用户名和密码,但是出现401界面. ...
- PHP防SQL注入攻击
PHP防SQL注入攻击 收藏 没有太多的过滤,主要是针对php和mysql的组合. 一般性的防注入,只要使用php的 addslashes 函数就可以了. 以下是一段copy来的代码: PHP代码 $ ...
- GCD之异步同步体会
前面的博文也有写到同步异步,可能是看他人的博文,自己没有实验,感觉理解不深,所以就敲了些代码比较一下串行.并行分别对应的同步.异步. 1.首先创建串行.并行线程队列 1 2 dispatch_queu ...
- Opengl4.5 中文手册—F
索引 A B C D E F G H I J K L M N O P Q ...
- #翻译#原文来自Database.System.Concepts(6th.Edition.2010)2.6Relational Operations,原文作者Abraham Silberschaz , Henry F. Korth , S. Sudarshan
2.6关系操作 所有的过程关系查询语言都提供一组操作,这些操作可以应用于单个关系或一对关系.这些操作具有良好的和期望的属性,它们的结果总是一个单一的关系.这个属性允许一个以模块化的方式组合其中的几个操 ...
- 01背包java实现(入门到精通)
一.什么是01背包 01背包是在M件物品取出若干件放在空间为W的背包里,每件物品的体积为W1,W2至Wn,与之相对应的价值为P1,P2至Pn.01背包是背包问题中最简单的问题.01背包的约束条件是给定 ...
- 设计模式学习之“观察者模式” [C#]
<深入浅出设计模式>学习笔记第二章 需求: 开发一套气象监测应用,如图: 气象站,目前有三种装置,温度.湿度和气压感应装置. WeatherData对象追踪气象站的数据,并更新到布告板,布 ...
- Dice (II) (DP)唉,当时没做出来
Dice (II) Time Limit: 3000MS Memory Limit: 32768KB 64bit IO Format: %lld & %llu [Submit] [ ...
- Angular学习笔记(一)
本文为原创文章,转载请标明出处 目录 架构 模块 组件 模板 元数据 数据绑定 指令 服务 依赖注入 模板与数据绑定 1. 架构 模块 Angular 应用是模块化的,并且 Angular 有自己的模 ...