環(huán)境:依賴最初test2數(shù)據(jù)庫(kù)
創(chuàng)新互聯(lián)建站堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的紅旗網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!python3版本
多python版本環(huán)境
進(jìn)入,python3虛擬環(huán)境,新建項(xiàng)目test4:
]# cd py3/django-test1/ ]# django-admin startproject test4
創(chuàng)建應(yīng)用bookshop:
]# cd test4 ]# python manage.py startapp bookshop
修改settings.py主配置文件:
]# vim test4/settings.py ... #數(shù)據(jù)庫(kù)為mysql,使用原來(lái)的test2數(shù)據(jù)庫(kù)名稱: DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'test2', 'USER': 'root', 'PASSWORD': 'root', 'HOST': '192.168.255.70', 'PORT': '3306', } } #添加應(yīng)用: INSTALLED_APPS = ( 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'bookshop', ) #添加模板查找路徑: TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [os.path.join(BASE_DIR,'templates')], ... ] ...
在項(xiàng)目名稱目錄下,添加模板目錄并在其下添加應(yīng)用的模板目錄:
]# mkdir -p templates/bookshop
在主url路由配置文件中,添加查找應(yīng)用url的路由:
]# vim test4/settings.py ... urlpatterns = [ url(r'^admin/', include(admin.site.urls)), url(r'^',include('bookshop.urls',namespace='bookshop')), ]
在應(yīng)用目錄下創(chuàng)建urls.py文件:
]# vim bookshop/urls.py from django.conf.urls import url from . import views urlpatterns = [ url(r'\^$',views.index,name='index'), ]
以上基本配置完成,下面演示在模板中調(diào)用對(duì)象的方法:
定義模型類:
為了不用遷移,定義模型類要和test2數(shù)據(jù)庫(kù)結(jié)構(gòu)一樣;
]# vim bookshop/models.py from django.db import models class BookInfo(models.Model): btitle = models.CharField(max_length=20) bpub_date = models.DateTimeField(db_column='pub_date') #定義字段名稱為pub_date,默認(rèn)字段名稱就是類屬性,即默認(rèn)字段名稱為bpub_date bread = models.IntegerField() bcommet = models.IntegerField() isDelete = models.BooleanField() #定義表名 class Meta(): db_table = 'bookinfo' #如果不寫上面2行,表名默認(rèn)為項(xiàng)目名稱.類名稱,即bookshop.bookinfo class HeroInfo(models.Model): hname = models.CharField(max_length=10) hgender = models.BooleanField() hcontent = models.CharField(max_length=1000) isDelete = models.BooleanField() book = models.ForeignKey('BookInfo') #定義外鍵,此處引號(hào)是否可省略,BookInfo先定義就可省略引號(hào),如果后定義則需要使用引號(hào),使用引號(hào)絕對(duì)沒(méi)錯(cuò);在表中字段自動(dòng)變?yōu)閎ook_id def showname(self): return self.hname
定義視圖:
]# vim bookshop/views.py from django.shortcuts import render from .models import * #from models import * #在python2寫法 def index(request): #必須接收一個(gè)參數(shù) hero = HeroInfo.objects.get(pk=1) #查詢主鍵(pk)=1的條目 context = {'hero':hero} #必須為字典格式 return render(request,'bookshop/index.html',context)
定義index.html模板文件:
]# vim templates/bookshop/index.htmlTitle {{ hero.hname }}
{{hero.showname}}
啟動(dòng)web服務(wù):
]# python manage.py runserver 192.168.255.70:8000 報(bào)錯(cuò):Error loading MySQLdb module: No module named 'MySQLdb'
解決:由于在python3版本上使用pymysql庫(kù),沒(méi)有MySQLdb庫(kù),則需要配置;
]# vim test4/__init__.py import pymysql pymysql.install_as_MySQLdb()
再次啟動(dòng)web服務(wù)成功;瀏覽器訪問(wèn):http://192.168.255.70:8000/
http://weahome.cn/article/cspojd.html