开发环境:

  1. 语言Python3.X以上
  2. MTV WEB框架 Django
  3. 前端框架 jQuery+bootstrap
  4. 数据库 MySQL

运行环境

  1. 安装Python3.x
  2. 安装Django
  3. 除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项目一的更多相关文章

  1. Python CRM项目二

    一.准备工作 如果没有配置基本的项目,请参考 http://www.cnblogs.com/luhuajun/p/7771196.html 当我们配置完成后首先准备我们的app 创建2个app分别对应 ...

  2. Python CRM项目八

    自定义用户认证 目的:实现Django自定义的认证系统,在生产环境都是根据此代码进行定制的 步骤: 1.在settings文件中配置要使用的类 #命名规则 app名称.类名 AUTH_USER_MOD ...

  3. Python CRM项目三

    1.分页: 分页使用Django内置的分页模块来实现 官方的分页案例 from django.core.paginator import Paginator, EmptyPage, PageNotAn ...

  4. Python CRM项目七

    仿照Django Admin实现对readonly的字段进行设置 功能点: 1.页面不可进行更改 2.如果改变html代码中的值,则需要进行后端的数据库数据校验 3.可以对某些字段进行自定制校验规则 ...

  5. Python CRM项目六

    自定义Django Admin的action 在Django Admin中,可以通过action来自定义一些操作,其中默认的action的功能是选中多条数据来进行删除操作 我们在king_admin中 ...

  6. Python CRM项目四

    实现Django Admin的多对多的复选框效果 效果:左边显示的是未选中的字段,右边显示的是已选中的字段,两边点击的标签可以互相更换 首先在king_admin.py中增加filter_horizo ...

  7. CRM项目总结

                CRM项目总结      一:开发背景 在公司日益扩大的过程中,不可避免的会伴随着更多问题出现. 对外 : 如何更好的管理客户与公司的关系?如何更及时的了解客户日益发展的需求变 ...

  8. CRM项目之RBAC权限组件-day26

    写在前面 上课第26天,打卡: 世间安得双全法 不负如来不负卿 s17day26 CRM项目 项目概要:XX公司CRM - 权限管理,公共组件,app ***** - 熟悉增删改查,Low *** - ...

  9. crm项目整理

    crm项目整理   一.开发背景 由于公司人员的增多,原来通过excel表格存取方式过于繁琐,而且对于公司人员的调配和绩效考核等不能做到精确处理,所以开发crm系统,开始开发只是针对销售人员和客户,后 ...

随机推荐

  1. bzoj 3212 Pku3468 A Simple Problem with Integers

    3212: Pku3468 A Simple Problem with Integers Time Limit: 1 Sec  Memory Limit: 128 MB Description You ...

  2. MySQL锁和事务(一):InnoDB锁(MySQL 官方文档粗翻)

    // 写在前面,实际上,数据库加锁的类型和范围受到多种因素的影响,例如数据库隔离等级,SQL语句,是否使用主键.索引等等.可以查看博文: http://www.cnblogs.com/zhaoyl/p ...

  3. Hive任务优化(1)

    一个Hive查询生成多个Map Reduce Job,一个Map Reduce Job又有Map,Reduce,Spill,Shuffle,Sort等多个阶段,所以针对Hive查询的优化可以大致分为针 ...

  4. hdu3695 ac自动机入门

    Computer Virus on Planet Pandora Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 256000/1280 ...

  5. Python自学笔记-lambda函数(来自廖雪峰的官网Python3)

    感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看. 匿名函数 通过 ...

  6. Python自学笔记-字符串编码(来自廖雪峰的官网Python3)

    感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看.   1.理解变 ...

  7. scala中的Type使用

    trait Base { val name: String } case class S( name: String, age: Int ) extends Base case class F( na ...

  8. masonry 设置控件抗压缩及抗拉伸

    使用masonry正常设置约束时两个label的显示是下图 添加代码设置蓝色label的抗压缩属性后( [self.missionNameLabel setContentCompressionResi ...

  9. MS-DOS命令dir命令详细解析

    DOS命令窗口打开方式为Win+R键,打开运行命令,输入 cmd 即可:特殊情况我们要用管理员身份运行DOS,此时就可以在开始菜单-附件-DOS命令,鼠标右键单击命令提示符以管理员身份运行.如果是wi ...

  10. win8.1 安装

    下载了Windows8.1企业版的iso文件,文件名称:cn_windows_8_1_enterprise_x86_dvd_2791409.iso 下载地址: http://msdn.itellyou ...