image.png
使用数据库
修改 models.py:
from django.db import models
# verbose_name 作为说明注释使用,可用于 csv 导出
class Student(models.Model):
name = models.CharField(verbose_name='姓名', max_length=50)
sex = models.CharField(verbose_name='性别', max_length=50)
age = models.IntegerField(verbose_name='年龄')
address = models.CharField(verbose_name='家庭住址', max_length=250)
enter_date = models.DateField(verbose_name='入学时间')
remarks = models.TextField(verbose_name='备注', blank=True)
需要明白的是,这里创建的是单个人物的数据模型,之后 Django 就能通过这个样板模型来进行数据的创建。
更新数据库:
D:\PRJ\student_management\Django_simple (master -> origin)
(py36) λ python manage.py makemigrations && python manage.py migrate
每次更改 models.py 都要运行一次 python manage.py makemigrations 和 python manage.py migrate。
啊,本质上 orm 就是将原本直接硬写的 sql 语句换成了 python 语句来写,这样我们就不需要记忆那些难记的 sql 语句了,但是也因为换成了 py 语句,所以我们需要手动对我们的 py 语句进行检测改动,然后被 orm 转换,最后作用于数据库。
SQLiteStudio 查看更改:
image.png
编写控制台信息
控制台由 admin.py 控制,最后用 xadmin.site.register 来注册上去。
# from django.contrib import admin
import xadmin
from app.models import *
class StudentsAdmin():
list_display = ('name', 'sex', 'age', 'address', 'enter_date', 'remarks',)
xadmin.site.register(Student, StudentsAdmin)
上传图片、附件,仅限开发环境
添加相关目录到 setting.py:
# 以下仅限开发环境,这不适合生产使用!
# 媒体文件根目录
MEDIA_URL = '/media/' # 网站的访问路径
MEDIA_ROOT = os.path.join(BASE_DIR, 'media') # MEDIA_ROOT 为提供图片的路径
往 models.py 的内 student 类新加入一个图片属性并设置 upload_to,这将会被解释为数据库上传图片:
class Student(models.Model):
name = models.CharField(verbose_name='姓名', max_length=50)
sex = models.CharField(verbose_name='性别', max_length=50)
age = models.IntegerField(verbose_name='年龄')
address = models.CharField(verbose_name='家庭住址', max_length=250)
enter_date = models.DateField(verbose_name='入学时间')
remarks = models.TextField(verbose_name='备注', blank=True)
pass
def path_photo(self, filename):
return os.path.join('photo', '%s_%s' % (self.name, self.sex))
photo = models.ImageField(verbose_name='照片', upload_to=path_photo, blank=True, null=True) # upload_to指定图片上传的途径,如果不存在则自动创建
编写 urls.py:
from django.contrib import admin
from django.urls import path
import xadmin
from django.conf import settings
from django.conf.urls.static import static
urlpatterns = [
path(r'', xadmin.site.urls),
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
注意
此辅助函数仅在调试模式下有效,并且仅当给定前缀是本地(例如/media/)而不是URL(例如 http://media.example.com/)时才有效。
配置完 Django 的后台管理页面就会自动显示上传图片的功能,网站访问时的相对路径则由 MEDIA_URL 提供。
真素神奇,就跟配置文件一样,这里面 TM 发生了什么?
测试:
image.png
导出依赖库
不给完整依赖库的都是大坑,节省时间乃是大事。
导出依赖库:
D:\PRJ\student_management\Django_simple (master -> origin)
(py36) λ pip freeze > requirements.txt
安装依赖:
pip install -r requirements.txt
看一眼,可以复制下来存到自己的 requirements.txt 里面安装:
D:\PRJ\student_management\Django_simple (master -> origin)
(py36) λ cat requirements.txt
asn1crypto==0.24.0
astroid==2.0.1
autopep8==1.3.5
certifi==2018.8.13
cffi==1.11.5
colorama==0.3.9
cryptography==2.2.2
diff-match-patch==20121119
Django==2.1
django-crispy-forms==1.7.2
django-filter==2.0.0
django-formtools==2.1
django-import-export==1.0.1
django-reversion==3.0.0
djangorestframework==3.8.2
et-xmlfile==1.0.1
future==0.16.0
httplib2==0.9.2
idna==2.7
isort==4.3.4
jdcal==1.4
Jinja2==2.10
lazy-object-proxy==1.3.1
Markdown==2.6.11
MarkupSafe==1.0
mccabe==0.6.1
mysqlclient==1.3.13
odfpy==1.3.6
openpyxl==2.5.5
Pillow==5.2.0
pycodestyle==2.4.0
pycparser==2.18
pylint==2.0.1
PyMySQL==0.9.2
pytz==2018.5
PyYAML==3.13
six==1.11.0
tablib==0.12.1
typed-ast==1.1.0
unicodecsv==0.14.1
wincertstore==0.2
wrapt==1.10.11
xadmin==2.0.1
xlrd==1.1.0
xlwt==1.3.0