day60 Pyhton 框架Django 03
生活随笔
收集整理的這篇文章主要介紹了
day60 Pyhton 框架Django 03
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
day61內(nèi)容回顧1.安裝1. 命令行:pip install django==1.11.18 pip install django==1.11.18 -i 源
2. pycharmsetting —》 解釋器 —》 點(diǎn)+號(hào) —》 輸入django —》 選擇版本—》安裝2.創(chuàng)建項(xiàng)目1. 命令行:django-admin startproject 項(xiàng)目名稱(chēng)1. pycharmfile ——》 new project ——》 django ——》 項(xiàng)目目錄 ——》選擇解釋器——》輸入app名稱(chēng) ——》創(chuàng)建3.啟動(dòng)項(xiàng)目1. 命令行:切換到項(xiàng)目根目錄下 manage.py python manage.py runserver # 127.0.0.1:8000python manage.py runserver 80 # 127.0.0.1:80python manage.py runserver 0.0.0.0:80 # 0.0.0.0:80
2. pycharm配置點(diǎn)擊綠三角4.urls.py地址和函數(shù)的對(duì)應(yīng)關(guān)系from django.conf.urls import urlfrom app01 import viewsurlpatterns = [url(r'^login/', views.login),url(r'^index/', views.index),url(r'^test/', views.test),]5.函數(shù)接收一個(gè)參數(shù):request 跟請(qǐng)求相關(guān)request.method 請(qǐng)求方法 GET POST request.POST form表單提交POST請(qǐng)求的數(shù)據(jù) {} get() [] request.GET url上的參數(shù) {} 返回值:from django.shotcuts import HttpResponse, render, redirectHttpResponse('顯示的內(nèi)容') ——》 字符串 render(request,‘HTML文件名’) ——》 返回一個(gè)完整的HTML頁(yè)面redirect('要跳轉(zhuǎn)的地址') ——》 重定向 Location : 地址6.app1.創(chuàng)建APP1. 命令行:python manage.py startapp app名稱(chēng)
2. pycharmtools ——》 run manage.py task ——》 startapp app名稱(chēng)2.注冊(cè)appINSTALLED_APPS = ['app01', 'app01.apps.App01Config', ]7.配置文件靜態(tài)文件:STATIC_URL = '/static/' # 別名STATICFILES_DIRS = [os.path.join(BASE_DIR,'static'), ]模板:TEMPLATES'DIRS': [os.path.join(BASE_DIR, 'templates')]中間件:注釋掉 'django.middleware.csrf.CsrfViewMiddleware'數(shù)據(jù)庫(kù)8.form表單1. action=‘’ method='post' action 提交的地址 method提交的方式
2. 所有的input標(biāo)簽要有name屬性
3. 要有一個(gè)type=submit input標(biāo)簽 或者 button按鈕9.get 和 post 區(qū)別get 獲取一個(gè)頁(yè)面地址?k1=v1&k2=v2request.GET post 提交數(shù)據(jù) request.POST10.django使用mysql數(shù)據(jù)庫(kù)的流程:1. 創(chuàng)建一個(gè)mysql數(shù)據(jù)庫(kù)
2. 配置ENGINE: mysqlNAME: 數(shù)據(jù)庫(kù)名HOST: IP '127.0.0.1' PORT : 3306USER: 'root'PASSWORD: ''
3. 告訴django使用pymysql模塊連接mysql數(shù)據(jù)庫(kù)在于settings同級(jí)目錄下的init.py中寫(xiě)import pymysqlpymsql.install_as_MySQLdb()
4. 創(chuàng)建表(在app下的models.py中寫(xiě)類(lèi))from django.db import modelsclass User(models.Model): # app名稱(chēng)_userusername = models.CharField(max_length=20) # varchar(20)password = models.CharField(max_length=20)def __str__(self):return self.username1. 執(zhí)行數(shù)據(jù)庫(kù)遷移的命令python manage.py makemigrations # 保存models變更記錄python manage.py migrate # 把變更記錄同步到數(shù)據(jù)庫(kù)中11.ORM面向?qū)ο蠛完P(guān)系型數(shù)據(jù)庫(kù)的一個(gè)映射映射關(guān)系類(lèi) ——》 表對(duì)象 ——》 數(shù)據(jù)行 屬性 ——》 字段ORM完成的操作:1. 操作數(shù)據(jù)表1. 操作數(shù)據(jù)ORM的簡(jiǎn)單操作:form app01 import models # 查詢(xún)所有的數(shù)據(jù)models.User.objects.all() # queryset 對(duì)象列表 # 查詢(xún)一個(gè)數(shù)據(jù)obj = models.User.objects.get(username='alex') # 對(duì)象 obj.username # 'alex' # 查詢(xún)滿足條件的所有數(shù)據(jù)models.User.objects.filter(username='alex') # 對(duì)象列表 今日內(nèi)容圖書(shū)管理系統(tǒng)單表的增刪改查1.展示設(shè)計(jì)數(shù)據(jù)表from django.db import modelsclass Publisher(models.Model):pid = models.AutoField(primary_key=True) # 主鍵name = models.CharField(max_length=32) # varchar(32)def __str__(self):return self.name設(shè)計(jì)URL:from app01 import viewsurlpatterns = [url(r'^admin/', admin.site.urls),url(r'^publisher/', views.publisher),]寫(xiě)函數(shù):from django.shortcuts import renderfrom app01 import models# 展示出版社列表def publisher(request):# 從數(shù)據(jù)庫(kù)獲取到所有的數(shù)據(jù)all_publisher = models.Publisher.objects.all()# 返回一個(gè)包含數(shù)據(jù)的頁(yè)面return render(request, 'publisher.html', {"all_publisher": all_publisher})寫(xiě)模板:<table border="1"><thead><tr><th>ID</th><th>名稱(chēng)</th></tr></thead><tbody>{% for i in all_publisher %}<tr><td>{{ i.pk }}</td><td>{{ i.name }}</td></tr>{% endfor %}</tbody></table>
?
轉(zhuǎn)載于:https://www.cnblogs.com/pythonz/p/10280384.html
總結(jié)
以上是生活随笔為你收集整理的day60 Pyhton 框架Django 03的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: [bzoj 5332][SDOI201
- 下一篇: 第十一章 串 (b2)蛮力匹配