python学习

Python学习打call第五十五天:Django框架配置

2019-04-10  本文已影响14人  暖A暖

今天我们学习Django框架配置,首先先来看一下如何在Django中创建APP!

1.Django中创建APP

首先我们打开PyCharm,找到之前你创建的Django项目,我的项目是First_Project

# 目的就是在django的sys.path模块搜索路径中的第一个位置加上apps的路径
sys.path.insert(0, os.path.join(BASE_DIR, 'apps'));
os.environ.setdefault"DJANGO_SETTINGS_MODULE", "First_Project.settings")
django.setup()

2.Django中创建static静态文件目录

配置static静态文件查找路径:
1.首先打开settings文件,找到STATIC_URL = '/static/',这表示指定static静态文件路径

2.但是在template中是无法使用这个路径的,因为没有把这个路径加入到项目的路径中,因此需要把static路径加入到项目的路径中我们需要添加一句代码:

# 表示把static路径加入到项目的路径中
STATICFILES_DIRS = (os.path.join(BASE_DIR, "static"), )

3.这样在template中引用这个静态文件就可以只要指定相对路径就好了

<link rel="stylesheet" type="text/css" href="{% static 'css/course/banner.css' %}"/> 

3.Django中创建media媒体文件目录

配置media媒体文件查找路径:
1.在settings文件中加入MEDIA_ROOT = os.path.join(BASE_DIR, 'media')语句,表示把用户上传的所有的东西,如图片等,保存到这个/media/目录下

2.如果我们想要图片上传到/media/banner/%Y/%m/目录下(Y表示年,m表示月),我们可以这样写

image = models.ImageField(max_length=100, upload_to='banner/%Y/%m', verbose_name='用户头像图片')

3.那么在前端的html页面中,我们就可以使用用户上传的图片或其他的可以在html页面显示的东西, 因为数据库中保存了图片上传的路径,{{ MEDIA_URL }}相当于 /media/{{ request.user.image }}相当于 user/1.png,那么 {{ MEDIA_URL }}{{ request.user.image }} 相当于 /media/user/1.png

<img width="20" height="20" src="{{ MEDIA_URL }}{{ request.user.image }}"/>

4.因此必须在urls.py文件中写个路由处理逻辑

from django.views.static import serve
url(r'^media/(?P<path>.*)', serve, {'document_root': MEDIA_ROOT})

我们要注意每次创建一个app都需要在settings中将它注册进来,如果不注册进来,那么执行migration的时候就不会生成表,将app的名称加入到INSTALLED_APPS中;

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'users',
    'courses',
    'teachers',
    'schools',
]

最后在点击Tool--> Run manage.py Task,在控制台中依次执行makemigrations和migrate生成数据库表

学习参考:https://www.9xkd.com/user/plan-view.html?id=2345964104

上一篇 下一篇

猜你喜欢

热点阅读