Python Day19-20(Django基礎)
阿新 • • 發佈:2017-08-21
hid 字符類 conf 技術 positive mysqld 劃線 too json
python manage.py syncdb
python manage.py makemigrations
python manage.py migrate python manage.py createsuperuser 數據庫配置 settings.py裏面2.Django的請求生命周期
一、Django基礎
1.基本配置補充
可以用pycharm一鍵創建工程和APP
其他常用命令: python manage.py runserver 1.1.1.1:8000 python manage.py startapp appname
python manage.py syncdb
python manage.py makemigrations
python manage.py migrate python manage.py createsuperuser 數據庫配置 settings.py裏面
DATABASES = { ‘default‘: {‘ENGINE‘: ‘django.db.backends.mysql‘, ‘NAME‘:‘dbname‘, ‘USER‘: ‘root‘, ‘PASSWORD‘: ‘xxx‘, ‘HOST‘: ‘‘, ‘PORT‘: ‘‘, } }
# 由於Django內部連接MySQL時使用的是MySQLdb模塊,而python3中還無此模塊,所以需要使用pymysql來代替 # 如下設置放置的與project同名的配置的 __init__.py文件中 import pymysql pymysql.install_as_MySQLdb()
2.Django的請求生命周期
路由系統 -> 視圖函數或類(獲取模板+數據=》渲染) -> 把字符串返回給用戶
3.路由系統
a.單一路由對應
url(r‘^index/$‘, views.index),
ps:$為結束符,是為了防止其他網址都被該路由截獲
b.基於正則的路由
url(r‘^index/(\d*)/‘, views.index), url(r‘^manage/(?P<name>\w*)/(?P<id>\d*)/‘, views.manage),
c.添加額外的參數
url(r‘^host/‘, views.host, {"id": 333}),
ps:這時host函數需要一個額外的參數來接收id
d.為路由映射設置名稱
url(r‘^home‘, views.home, name=‘h1‘), url(r‘^index/(\d*)‘, views.index, name=‘h2‘),設置名稱之後,可以在不同的地方調用,如:
- 模板中使用生成URL {% url ‘h2‘ 2012 %}
- 函數中使用生成URL reverse(‘h2‘, args=(2012,)) 路徑:django.urls.reverse
- Model中使用獲取URL 自定義get_absolute_url() 方法
class NewType(models.Model): caption = models.CharField(max_length=16) def get_absolute_url(self): """ 為每個對象生成一個URL 應用:在對象列表中生成查看詳細的URL,使用此方法即可!!! :return: """ # return ‘/%s/%s‘ % (self._meta.db_table, self.id) # 或 from django.urls import reverse return reverse(‘NewType.Detail‘, kwargs={‘nid‘: self.id})
e.根據app對路由規則進行分類,路由分發
首先導入from django.conf.urls import include
url(r‘^web/‘,include(‘web.urls‘)),
4.視圖
Django視圖有兩種,分別是FBV和CBV a.FBV function base viewdef index(request, *args, **kwargs): passb.CBV class base view
from django.views import View class Home(View): def dispath(self, request, *args, **kwargs): print("before") result = super(Home, self).dispath(request, *args, **kwargs) print("after") return result def get(self, request): print(request.method) return render(request, "home.html") def post(self, request): print(request.method) return render(request, "home.html")
獲取用戶請求中的數據:
def index(request): request.method ===> 獲取請求方式 POST,GET........ request.POST.get("字段") request.GET.get("字段") request.FILES.get("字段") # 對於checkbox,select等,如有選擇了多個值,得用以下方法獲取 request.POST.getlist("字段") # 獲取的是一個列表 文件的獲取: 前提:需要form表單特殊處理,加上enctype="multipart/form-data" file_obj = request.FILES.get("字段") file_obj.name # 文件名字 file_obj.size # 文件大小 file_obj.chunks() # 用來獲取文件內容f = open(file_obj.name, "wb") for line in file_obj.chunks(): f.write(line) f.close() # 或者 f = open(file_obj.name, "wb") for line in file_obj: # 循環對象本身會自動去file_obj.chunks()裏面獲取文件內容 f.write(line) f.close()
給用戶返回數據:
return render(request, "模板的文件的路徑", {‘k1‘: [1,2,3,4],"k2": {‘name‘: ‘張揚‘,‘age‘: 73}}) return redirect("URL") return HttpResponse("字符串")
5.模板語言
後端返回:
render(request, "模板的文件的路徑", {‘obj‘: 1234, ‘k1‘: [1,2,3,4],"k2": {‘name‘: ‘張揚‘,‘age‘: 73}})
前端獲取:
a.單個數據獲取
<html> <body> <h1>{{ obj }}</h1> # 字符串直接寫變量名即可 <h1>{{ k1.0 }}</h1> # 列表則是.索引 <h1>{{ k2.name }}</h1> # 字典則是.key </body> </html>
b.獲取所有數據,比如:列表和字典中所有數據
<html> <body> <!-- 列表循環 --> {% for i in k1 % } <h1>{{ i }}</h1> {% endfor % } <!-- 字典循環 --> {% for k in k2.keys % } <h1>{{ k }}</h1> {% endfor % } {% for v in k2.values % } <h1>{{ v }}</h1> {% endfor % } {% for k,v in k2.items % } <h1>{{ k }}-{{ v }}</h1> {% endfor % } </body> </html>
c.判斷
{% if ordered_warranty %} {% else %} {% endif %}
6.Model
數據庫操作有兩種原則:- DB First 即:通過數據中的表結構自動生成相關的類
- Code First 即:根據代碼中定義的類來自動生成數據庫中的表
from django.db import models class userinfo(models.Model): name = models.CharField(max_length=30) # 字符長度 email = models.EmailField() memo = models.TextField()
字段:
AutoField(Field) - int自增列,必須填入參數 primary_key=True BigAutoField(AutoField) - bigint自增列,必須填入參數 primary_key=True 註:當model中如果沒有自增列,則自動會創建一個列名為id的列 from django.db import models class UserInfo(models.Model): # 自動創建一個列名為id的且為自增的整數列 username = models.CharField(max_length=32) class Group(models.Model): # 自定義自增列 nid = models.AutoField(primary_key=True) name = models.CharField(max_length=32) SmallIntegerField(IntegerField): - 小整數 -32768 ~ 32767 PositiveSmallIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField) - 正小整數 0 ~ 32767 IntegerField(Field) - 整數列(有符號的) -2147483648 ~ 2147483647 PositiveIntegerField(PositiveIntegerRelDbTypeMixin, IntegerField) - 正整數 0 ~ 2147483647 BigIntegerField(IntegerField): - 長整型(有符號的) -9223372036854775808 ~ 9223372036854775807 自定義無符號整數字段 class UnsignedIntegerField(models.IntegerField): def db_type(self, connection): return ‘integer UNSIGNED‘ PS: 返回值為字段在數據庫中的屬性,Django字段默認的值為: ‘AutoField‘: ‘integer AUTO_INCREMENT‘, ‘BigAutoField‘: ‘bigint AUTO_INCREMENT‘, ‘BinaryField‘: ‘longblob‘, ‘BooleanField‘: ‘bool‘, ‘CharField‘: ‘varchar(%(max_length)s)‘, ‘CommaSeparatedIntegerField‘: ‘varchar(%(max_length)s)‘, ‘DateField‘: ‘date‘, ‘DateTimeField‘: ‘datetime‘, ‘DecimalField‘: ‘numeric(%(max_digits)s, %(decimal_places)s)‘, ‘DurationField‘: ‘bigint‘, ‘FileField‘: ‘varchar(%(max_length)s)‘, ‘FilePathField‘: ‘varchar(%(max_length)s)‘, ‘FloatField‘: ‘double precision‘, ‘IntegerField‘: ‘integer‘, ‘BigIntegerField‘: ‘bigint‘, ‘IPAddressField‘: ‘char(15)‘, ‘GenericIPAddressField‘: ‘char(39)‘, ‘NullBooleanField‘: ‘bool‘, ‘OneToOneField‘: ‘integer‘, ‘PositiveIntegerField‘: ‘integer UNSIGNED‘, ‘PositiveSmallIntegerField‘: ‘smallint UNSIGNED‘, ‘SlugField‘: ‘varchar(%(max_length)s)‘, ‘SmallIntegerField‘: ‘smallint‘, ‘TextField‘: ‘longtext‘, ‘TimeField‘: ‘time‘, ‘UUIDField‘: ‘char(32)‘, BooleanField(Field) - 布爾值類型 NullBooleanField(Field): - 可以為空的布爾值 CharField(Field) - 字符類型 - 必須提供max_length參數, max_length表示字符長度 TextField(Field) - 文本類型 EmailField(CharField): - 字符串類型,Django Admin以及ModelForm中提供驗證機制 IPAddressField(Field) - 字符串類型,Django Admin以及ModelForm中提供驗證 IPV4 機制 GenericIPAddressField(Field) - 字符串類型,Django Admin以及ModelForm中提供驗證 Ipv4和Ipv6 - 參數: protocol,用於指定Ipv4或Ipv6, ‘both‘,"ipv4","ipv6" unpack_ipv4, 如果指定為True,則輸入::ffff:192.0.2.1時候,可解析為192.0.2.1,開啟刺功能,需要protocol="both" URLField(CharField) - 字符串類型,Django Admin以及ModelForm中提供驗證 URL SlugField(CharField) - 字符串類型,Django Admin以及ModelForm中提供驗證支持 字母、數字、下劃線、連接符(減號) CommaSeparatedIntegerField(CharField) - 字符串類型,格式必須為逗號分割的數字 UUIDField(Field) - 字符串類型,Django Admin以及ModelForm中提供對UUID格式的驗證 FilePathField(Field) - 字符串,Django Admin以及ModelForm中提供讀取文件夾下文件的功能 - 參數: path, 文件夾路徑 match=None, 正則匹配 recursive=False, 遞歸下面的文件夾 allow_files=True, 允許文件 allow_folders=False, 允許文件夾 FileField(Field) - 字符串,路徑保存在數據庫,文件上傳到指定目錄 - 參數: upload_to = "" 上傳文件的保存路徑 storage = None 存儲組件,默認django.core.files.storage.FileSystemStorage ImageField(FileField) - 字符串,路徑保存在數據庫,文件上傳到指定目錄 - 參數: upload_to = "" 上傳文件的保存路徑 storage = None 存儲組件,默認django.core.files.storage.FileSystemStorage width_field=None, 上傳圖片的高度保存的數據庫字段名(字符串) height_field=None 上傳圖片的寬度保存的數據庫字段名(字符串) DateTimeField(DateField) - 日期+時間格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] DateField(DateTimeCheckMixin, Field) - 日期格式 YYYY-MM-DD TimeField(DateTimeCheckMixin, Field) - 時間格式 HH:MM[:ss[.uuuuuu]] DurationField(Field) - 長整數,時間間隔,數據庫中按照bigint存儲,ORM中獲取的值為datetime.timedelta類型 FloatField(Field) - 浮點型 DecimalField(Field) - 10進制小數 - 參數: max_digits,小數總長度 decimal_places,小數位長度 BinaryField(Field) - 二進制類型View Code
參數:
null 數據庫中字段是否可以為空 db_column 數據庫中字段的列名 db_tablespace default 數據庫中字段的默認值 primary_key 數據庫中字段是否為主鍵 db_index 數據庫中字段是否可以建立索引 unique 數據庫中字段是否可以建立唯一索引 unique_for_date 數據庫中字段【日期】部分是否可以建立唯一索引 unique_for_month 數據庫中字段【月】部分是否可以建立唯一索引 unique_for_year 數據庫中字段【年】部分是否可以建立唯一索引 auto_now 創建時,自動生成時間 auto_now_add 更新時,自動更新為當前時間 ps:需要使用obj.save()的方式才行 verbose_name Admin中顯示的字段名稱 blank Admin中是否允許用戶輸入為空 editable Admin中是否可以編輯 help_text Admin中該字段的提示信息 choices Admin中顯示選擇框的內容,用不變動的數據放在內存中從而避免跨表操作 如:gf = models.IntegerField(choices=[(0, ‘何穗‘),(1, ‘大表姐‘),],default=1) error_messages 自定義錯誤信息(字典類型),從而定制想要顯示的錯誤信息; 字典健:null, blank, invalid, invalid_choice, unique, and unique_for_date 如:{‘null‘: "不能為空.", ‘invalid‘: ‘格式錯誤‘} validators 自定義錯誤驗證(列表類型),從而定制想要的驗證規則 from django.core.validators import RegexValidator from django.core.validators import EmailValidator,URLValidator,DecimalValidator, MaxLengthValidator,MinLengthValidator,MaxValueValidator,MinValueValidator 如: test = models.CharField( max_length=32, error_messages={ ‘c1‘: ‘優先錯信息1‘, ‘c2‘: ‘優先錯信息2‘, ‘c3‘: ‘優先錯信息3‘, }, validators=[ RegexValidator(regex=‘root_\d+‘, message=‘錯誤了‘, code=‘c1‘), RegexValidator(regex=‘root_112233\d+‘, message=‘又錯誤了‘, code=‘c2‘), EmailValidator(message=‘又錯誤了‘, code=‘c3‘), ] )
類創建或者修改之後,執行下面兩句代碼:
python manage.py makemigrations
python manage.py migrate
ps:需要先在settings.py裏面註冊app
b.操作: 增加:models.User.objects.create(name=‘qianxiaohu‘,age=18) dic = {‘name‘: ‘xx‘, ‘age‘: 19} models.User.objects.create(**dic) obj = models.User(name=‘qianxiaohu‘,age=18) obj.save()
刪除:
models.User.objects.filter(id=1).delete()
修改:
models.User.objects.filter(id__gt=1).update(name=‘alex‘,age=84) dic = {‘name‘: ‘xx‘, ‘age‘: 19} models.User.objects.filter(id__gt=1).update(**dic)
查找:
models.User.objects.filter(id=1,name=‘root‘) # id等於1和name等於root models.User.objects.filter(id__gt=1,name=‘root‘) # id > 1 和name等於root models.User.objects.filter(id__lt=1) # id < 1 models.User.objects.filter(id__gte=1) # id >= 1 models.User.objects.filter(id__lte=1) # id <= 1 models.User.objects.filter(id=1,name=‘root‘) dic = {‘name‘: ‘xx‘, ‘age__gt‘: 19} models.User.objects.filter(**dic) v1 = models.Business.objects.all() # QuerySet ,內部元素都是對象 v2 = models.Business.objects.all().values(‘id‘,‘caption‘) # QuerySet ,內部元素都是字典 v3 = models.Business.objects.all().values_list(‘id‘,‘caption‘) # QuerySet ,內部元素都是元組 models.Business.objects.get(id=1) # 獲取到的一個對象,如果不存在就報錯 models.Business.objects.filter(id=1).first() # 獲取到的將是一個對象,獲取不到則返回None obj = models.Host.objects.filter(id=1).first() obj.外鍵.字段 # 可以跨表查詢c.外鍵:
- 一對多
class UserType(models.Model): caption = models.CharField(max_length=32) class User(models.Model): age = models.IntergerFiled() name = models.CharField(max_length=10) # 字符長度 user_type = models.ForeignKey("UserType",to_field=‘id‘) # 約束 ps:數據庫生成的將是user_type_id
- 多對多
class Host(models.Model): nid = models.AutoField(primary_key=True) hostname = models.CharField(max_length=32,db_index=True) ip = models.GenericIPAddressField(protocol="ipv4",db_index=True) port = models.IntegerField() b = models.ForeignKey(to="Business", to_field=‘id‘) # 10 class Application(models.Model): name = models.CharField(max_length=32) # 2 class HostToApp(models.Model): # 自己定義第三張表,可以隨意在此增加字段 hobj = models.ForeignKey(to=‘Host‘,to_field=‘nid‘) aobj = models.ForeignKey(to=‘Application‘,to_field=‘id‘) # HostToApp.objects.create(hobj_id=1,aobj_id=2)
方式二:自動創建關系表
class Host(models.Model): nid = models.AutoField(primary_key=True) hostname = models.CharField(max_length=32,db_index=True) ip = models.GenericIPAddressField(protocol="ipv4",db_index=True) port = models.IntegerField() b = models.ForeignKey(to="Business", to_field=‘id‘) # 10 class Application(models.Model): name = models.CharField(max_length=32) hosts = models.ManyToManyField("Host")
自動生成第三張表,也就是說無法直接對第三張表進行操作
obj = Application.objects.get(id=1) obj.name # 第三張表操作 obj.hosts.add(1) # 增加對應主機 obj.hosts.add(2) obj.hosts.add(2,3,4) obj.hosts.add(*[1,2,3,4]) obj.hosts.remove(1) # 移除對應主機 obj.hosts.remove(2,4) obj.hosts.remove(*[1,2,3]) obj.hosts.clear() # 清空所有對應主機 obj.hosts.set([3,5,7]) # 更新,只保留set設置的主機 # 所有相關的主機對象“列表” QuerySet obj.hosts.all()
7.Ajax
$.ajax({ url: ‘/host/‘, type: "POST", data: {‘k1‘: 123,‘k2‘: "root"}, // 另外一種方便的辦法是找到form標簽打包發送: $("#formid").serialize(), dataType: "JSON", // 內部會自動將返回的數據用JSON解析 traditional: true, // 這樣設置之後ajax就可以發送多數據了,比如列表 success: function(obj){ console.log(obj); } })建議:永遠讓服務器端返回一個字典 import json ..... return HttpResponse(json.dumps(字典))
Python Day19-20(Django基礎)