目錄
[TOC]
判斷字段值是否包含某個(gè)數(shù)字,如果是字符,建議用icontains
Entry.objects.filter(Q(id__contains='1') & Q(id__contains='2') & Q(id__contains='3'))
Entry.objects.filter(Q(id__contains=1) & Q(id__contains=2) & Q(id__contains=3))
Entry.objects.filter(reduce(Q(id__contains=x) for x in [1, 2, 3]))
管理員身份運(yùn)行cmd配置虛擬環(huán)境
- mkvirtualenv youpinmodel
- pip install django==1.9.8
- 下載python的mysql驅(qū)動(dòng)轩娶,進(jìn)入到文件目錄cd /d C:\Users\Administrator\Desktop
pip install mysql(tab) - 在虛擬環(huán)境youpinmodel中新建項(xiàng)目
- pip install pillow
根據(jù)項(xiàng)目需求設(shè)計(jì)app
- users-用戶管理
- employee-考核對象管理
- institution-制度管理
- informationinput-考核信息錄入
配置數(shù)據(jù)庫連接
#數(shù)據(jù)庫連接配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': "youpin1",
'USER':'root',
'PASSWORD':'',
'HOST':'127.0.0.1'
}
}
新建users app
新建users app
startapp users
model配置
#載入utf8編碼
# _*_ encoding:utf-8 _*_
#繼承app
from django.contrib.auth.models import AbstractUser
#新建模型框往,CharField要定義max_length
class UserProfile(AbstractUser):
nick_name = models.CharField(max_length=50, verbose_name=u"昵稱", default="")
birday = models.DateField(verbose_name=u"生日", null=True, blank=True)
gender = models.CharField(max_length=6, choices=(("male",u"男"),("female","女")), default="female")
image = models.ImageField(upload_to="image/%Y/%m",default=u"image/default.png", max_length=100)
user_id = models.CharField(max_length=11, null=True, blank=True)
class Meta:
verbose_name = "用戶信息"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.username
將UserProfile注冊到app中,并重載setting方法
此步前一定要restart一下椰弊,否則后面xadmin就要重新生成auth_user,或者注釋掉下面一句重新生成下表
AUTH_USER_MODEL = "users.UserProfile"
生成user表
makemigrations users
migrate users
新建剩余app
考核對象表
class w_section(models.Model):
w_sectionid = models.CharField(max_length=2, verbose_name=u"工段ID")
name = models.CharField(max_length=50, verbose_name=u"工段名")
class Meta:
verbose_name = u"工段"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.name
class w_team(models.Model):
w_teamid = models.CharField(max_length=4, verbose_name=u"車間班組ID",default=0)
name = models.CharField(max_length=50, verbose_name=u"車間班組名")
class Meta:
verbose_name = u"車間班組"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.name
class w_employee(models.Model):
w_employeeid = models.CharField(max_length=10, verbose_name=u"員工編號(hào)",default=0)
name = models.CharField(max_length=50, verbose_name=u"員工姓名")
w_sectionid = models.ForeignKey(w_section, verbose_name=u"所屬工段")
w_teamid = models.ForeignKey(w_team, verbose_name=u"所屬車間班組")
class Meta:
verbose_name = u"員工信息管理"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.name
制度表
class inscategory(models.Model):
categoryid = models.CharField(max_length=2, verbose_name=u"制度類別ID")
category = models.CharField(max_length=50, verbose_name=u"制度類別")
class Meta:
verbose_name = u"制度分類"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.category
class institution(models.Model):
categoryid = models.ForeignKey(inscategory, verbose_name=u"制度類別ID")
institution = models.CharField(max_length=50, verbose_name=u"制度內(nèi)容")
institutionid = models.CharField(max_length=10, verbose_name=u"制度ID")
score = models.CharField(max_length=2, verbose_name=u"加扣分")
class Meta:
verbose_name = u"制度"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.institutionid
考核信息錄入贤重,操作上面兩張表
class informationinput(models.Model):
"考核信息錄入"
user=models.ForeignKey(UserProfile,verbose_name=u"考核員")
category=models.ForeignKey(institution,verbose_name="制度ID和加扣分")
sketch=models.CharField(max_length=500,verbose_name=u"簡述")
w_employeeid = models.ForeignKey(w_employee, verbose_name=u"考核對象")
add_time=models.DateTimeField(default=datetime.now, verbose_name=u"添加時(shí)間")
image = models.ImageField(upload_to="information/%y/%m", default=u"information/default.png", max_length=100)
has_agree=models.BooleanField(default=False,verbose_name=u"是否審查通過")
class Meta:
verbose_name = u"考核信息"
verbose_name_plural = verbose_name
將所有app放到apps文件夾下
import sys
sys.path.insert(0, os.path.join(BASE_DIR, 'apps'))
python manage.py runserver 0.0.0.0:8000
后臺(tái)管理配置
createsuperuser
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'
USE_I18N = True
USE_L10N = True
USE_TZ = False
#使用本地時(shí)間
安裝xadmin
pip install xadmin
#注冊app
'xadmin',
'crispy_forms',
#url注冊
import xadmin
url(r'^xadmin/', xadmin.site.urls),
#同步表
makemigrations
migrate
#移動(dòng)xadmin到extra_apps中清焕,并mark
sys.path.insert(0, os.path.join(BASE_DIR, 'extra_apps'))
pip uninstall xadmin
makemigrations xadmin
migrate xadmin
設(shè)置模板祭犯,注冊其它app
# -*- coding: utf-8 -*-
__author__ = 'grl'
__date__ = '$DATE $TIME'
#制度app
import xadmin
from .models import inscategory,institution
class inscategoryAdmin(object):
list_display = ['categoryid', 'category']
search_fields = ['categoryid', 'category']
list_filter = ['categoryid', 'category']
class institutionAdmin(object):
list_display = ['categoryid', 'institution','institutionid','score']
search_fields = ['categoryid', 'institution','institutionid','score']
list_filter = ['categoryid', 'institution','institutionid','score']
xadmin.site.register(inscategory, inscategoryAdmin)
xadmin.site.register(institution, institutionAdmin)
#員工app
import xadmin
from .models import w_section,w_team,w_employee
class w_sectionAdmin(object):
list_display = ['w_sectionid', 'name']
search_fields = ['w_sectionid', 'name']
list_filter = ['w_sectionid', 'name']
class w_teamAdmin(object):
list_display = ['w_teamid', 'name']
search_fields = ['w_teamid', 'name']
list_filter = ['w_teamid', 'name']
class w_employeeAdmin(object):
list_display = ['w_employeeid', 'name','w_sectionid','w_teamid']
search_fields = ['w_employeeid', 'name','w_sectionid','w_teamid']
list_filter = ['w_employeeid', 'name','w_sectionid','w_teamid']
xadmin.site.register(w_section, w_sectionAdmin)
xadmin.site.register(w_team, w_teamAdmin)
xadmin.site.register(w_employee, w_employeeAdmin)
#考核信息錄入app
import xadmin
from .models import informationinput
class informationinputAdmin(object):
list_display = ['user', 'category','sketch','w_employeeid','add_time','image','has_agree']
search_fields = ['user', 'category','sketch','w_employeeid','add_time','image','has_agree']
list_filter = ['user', 'category','sketch','w_employeeid','add_time','image','has_agree']
xadmin.site.register(informationinput, informationinputAdmin)
#用戶adminx中配置全站基礎(chǔ)
import xadmin
from xadmin import views
class BaseSetting(object):
enable_themes = True
use_bootswatch = True
class GlobalSettings(object):
site_title = "信息后臺(tái)管理系統(tǒng)"
site_footer = ""
xadmin.site.register(views.BaseAdminView, BaseSetting)
xadmin.site.register(views.CommAdminView, GlobalSettings)
#apps.py中配置中文顯示
# -*- coding: utf-8 -*-
verbose_name = u"制度管理"
#_init_文件中配置
default_app_config = "institution.apps.InstitutionConfig"
問題總結(jié)
- 獲取當(dāng)前用戶姓名:
重載save_models方法 直接在方法中通過self.request.user就可以獲取到當(dāng)前操作xadmin的用戶了
- 外鍵過濾
def get_context(self):
context = superCourseAdmin, self).get_context()
if 'form' in context:
context['form'].fields['course_org'].queryset = CourseOrg.objects.filter(is_main_stage=True)
return context
#在adminx里面重載這個(gè)函數(shù)滚停,在xadmin中可以直接配置外鍵過濾 比如course的teacher是外鍵 如果要通過teacher的name過濾 直接在filter中寫 "teahcer__name"就行了, 注意是雙下劃線
- 設(shè)置mysql只能本地訪問
配置mysql的bind-addr 只需要配置成127.0.0.1
獲取用戶名等
- 獲取當(dāng)前用戶姓名:
重載save_models方法 直接在方法中通過self.request.user就可以獲取到當(dāng)前操作xadmin的用戶了
- 外鍵過濾
def get_context(self):
context = superCourseAdmin, self).get_context()
if 'form' in context:
context['form'].fields['course_org'].queryset = CourseOrg.objects.filter(is_main_stage=True)
return context
#在adminx里面重載這個(gè)函數(shù)键畴,在xadmin中可以直接配置外鍵過濾 比如course的teacher是外鍵 如果要通過teacher的name過濾 直接在filter中寫 "teahcer__name"就行了, 注意是雙下劃線
- 設(shè)置mysql只能本地訪問
配置mysql的bind-addr 只需要配置成127.0.0.1
管理員身份運(yùn)行cmd配置虛擬環(huán)境
- mkvirtualenv youpinmodel
- pip install django==1.9.8
- 下載python的mysql驅(qū)動(dòng)起惕,進(jìn)入到文件目錄cd /d C:\Users\Administrator\Desktop
pip install mysql(tab) - 在虛擬環(huán)境youpinmodel中新建項(xiàng)目
- pip install pillow
根據(jù)項(xiàng)目需求設(shè)計(jì)app
- users-用戶管理
- employee-考核對象管理
- institution-制度管理
- informationinput-考核信息錄入
配置數(shù)據(jù)庫連接
#數(shù)據(jù)庫連接配置
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': "youpin1",
'USER':'root',
'PASSWORD':'',
'HOST':'127.0.0.1'
}
}
新建users app
新建users app
startapp users
model配置
#載入utf8編碼
# _*_ encoding:utf-8 _*_
#繼承app
from django.contrib.auth.models import AbstractUser
#新建模型,CharField要定義max_length
class UserProfile(AbstractUser):
nick_name = models.CharField(max_length=50, verbose_name=u"昵稱", default="")
birday = models.DateField(verbose_name=u"生日", null=True, blank=True)
gender = models.CharField(max_length=6, choices=(("male",u"男"),("female","女")), default="female")
image = models.ImageField(upload_to="image/%Y/%m",default=u"image/default.png", max_length=100)
user_id = models.CharField(max_length=11, null=True, blank=True)
class Meta:
verbose_name = "用戶信息"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.username
將UserProfile注冊到app中惹想,并重載setting方法
此步前一定要restart一下,否則后面xadmin就要重新生成auth_user勺馆,或者注釋掉下面一句重新生成下表
AUTH_USER_MODEL = "users.UserProfile"
生成user表
makemigrations users
migrate users
新建剩余app
考核對象表
class w_section(models.Model):
w_sectionid = models.CharField(max_length=2, verbose_name=u"工段ID")
name = models.CharField(max_length=50, verbose_name=u"工段名")
class Meta:
verbose_name = u"工段"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.name
class w_team(models.Model):
w_teamid = models.CharField(max_length=4, verbose_name=u"車間班組ID",default=0)
name = models.CharField(max_length=50, verbose_name=u"車間班組名")
class Meta:
verbose_name = u"車間班組"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.name
class w_employee(models.Model):
w_employeeid = models.CharField(max_length=10, verbose_name=u"員工編號(hào)",default=0)
name = models.CharField(max_length=50, verbose_name=u"員工姓名")
w_sectionid = models.ForeignKey(w_section, verbose_name=u"所屬工段")
w_teamid = models.ForeignKey(w_team, verbose_name=u"所屬車間班組")
class Meta:
verbose_name = u"員工信息管理"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.name
制度表
class inscategory(models.Model):
categoryid = models.CharField(max_length=2, verbose_name=u"制度類別ID")
category = models.CharField(max_length=50, verbose_name=u"制度類別")
class Meta:
verbose_name = u"制度分類"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.category
class institution(models.Model):
categoryid = models.ForeignKey(inscategory, verbose_name=u"制度類別ID")
institution = models.CharField(max_length=50, verbose_name=u"制度內(nèi)容")
institutionid = models.CharField(max_length=10, verbose_name=u"制度ID")
score = models.CharField(max_length=2, verbose_name=u"加扣分")
class Meta:
verbose_name = u"制度"
verbose_name_plural = verbose_name
def __unicode__(self):
return self.institutionid
考核信息錄入,操作上面兩張表
class informationinput(models.Model):
"考核信息錄入"
user=models.ForeignKey(UserProfile,verbose_name=u"考核員")
category=models.ForeignKey(institution,verbose_name="制度ID和加扣分")
sketch=models.CharField(max_length=500,verbose_name=u"簡述")
w_employeeid = models.ForeignKey(w_employee, verbose_name=u"考核對象")
add_time=models.DateTimeField(default=datetime.now, verbose_name=u"添加時(shí)間")
image = models.ImageField(upload_to="information/%y/%m", default=u"information/default.png", max_length=100)
has_agree=models.BooleanField(default=False,verbose_name=u"是否審查通過")
class Meta:
verbose_name = u"考核信息"
verbose_name_plural = verbose_name
將所有app放到apps文件夾下
import sys
sys.path.insert(0, os.path.join(BASE_DIR, 'apps'))
python manage.py runserver 0.0.0.0:8000
后臺(tái)管理配置
createsuperuser
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'
USE_I18N = True
USE_L10N = True
USE_TZ = False
#使用本地時(shí)間
安裝xadmin
pip install xadmin
#注冊app
'xadmin',
'crispy_forms',
#url注冊
import xadmin
url(r'^xadmin/', xadmin.site.urls),
#同步表
makemigrations
migrate
#移動(dòng)xadmin到extra_apps中灌灾,并mark
sys.path.insert(0, os.path.join(BASE_DIR, 'extra_apps'))
pip uninstall xadmin
makemigrations xadmin
migrate xadmin
設(shè)置模板,注冊其它app
# -*- coding: utf-8 -*-
__author__ = 'grl'
__date__ = '$DATE $TIME'
#制度app
import xadmin
from .models import inscategory,institution
class inscategoryAdmin(object):
list_display = ['categoryid', 'category']
search_fields = ['categoryid', 'category']
list_filter = ['categoryid', 'category']
class institutionAdmin(object):
list_display = ['categoryid', 'institution','institutionid','score']
search_fields = ['categoryid', 'institution','institutionid','score']
list_filter = ['categoryid', 'institution','institutionid','score']
xadmin.site.register(inscategory, inscategoryAdmin)
xadmin.site.register(institution, institutionAdmin)
#員工app
import xadmin
from .models import w_section,w_team,w_employee
class w_sectionAdmin(object):
list_display = ['w_sectionid', 'name']
search_fields = ['w_sectionid', 'name']
list_filter = ['w_sectionid', 'name']
class w_teamAdmin(object):
list_display = ['w_teamid', 'name']
search_fields = ['w_teamid', 'name']
list_filter = ['w_teamid', 'name']
class w_employeeAdmin(object):
list_display = ['w_employeeid', 'name','w_sectionid','w_teamid']
search_fields = ['w_employeeid', 'name','w_sectionid','w_teamid']
list_filter = ['w_employeeid', 'name','w_sectionid','w_teamid']
xadmin.site.register(w_section, w_sectionAdmin)
xadmin.site.register(w_team, w_teamAdmin)
xadmin.site.register(w_employee, w_employeeAdmin)
#考核信息錄入app
import xadmin
from .models import informationinput
class informationinputAdmin(object):
list_display = ['user', 'category','sketch','w_employeeid','add_time','image','has_agree']
search_fields = ['user', 'category','sketch','w_employeeid','add_time','image','has_agree']
list_filter = ['user', 'category','sketch','w_employeeid','add_time','image','has_agree']
xadmin.site.register(informationinput, informationinputAdmin)
#用戶adminx中配置全站基礎(chǔ)
import xadmin
from xadmin import views
class BaseSetting(object):
enable_themes = True
use_bootswatch = True
class GlobalSettings(object):
site_title = "信息后臺(tái)管理系統(tǒng)"
site_footer = ""
xadmin.site.register(views.BaseAdminView, BaseSetting)
xadmin.site.register(views.CommAdminView, GlobalSettings)
#apps.py中配置中文顯示
# -*- coding: utf-8 -*-
verbose_name = u"制度管理"
#_init_文件中配置
default_app_config = "institution.apps.InstitutionConfig"