第一步:安装python环境。
1、最初安装的是python的64位版本,后来考虑到本机有oracle的客户端,是32位版本的,所以重新安装了python3.6.8的32位,安装包非常简单,就不再叙述,到官网上下载安装即可。安装后注意一下把python.exe的路径加入到环境变量中去。
2、安装django。
命令很简单:如下,然后安装mysqlclient(连mysql数据库),安装cx_oracle(连oracle数据库) 同样使用pip install即可
pip install django
在安装mysqlclient的时候,64位的没有任何问题,pip install mysqlclient直接通过,后来在安装python32位,pip install mysqlclient时候报没有vc++ 14的 时候,需要下载安装vc++库。 再次pip install mysqlclient时仍报错的话,到官网上下载对应python版本的mysqlclient, 下载地址 https://www.lfd.uci.edu/~gohlke/pythonlibs/#mysqlclient
第二步:配置开发ide环境。
(1) sublime text3 启动快,界面漂亮,可以配置python的语法提示,具体配置方法 请到 https://blog.csdn.net/xmm1981/article/details/78931029 参考设置。不过即使安装了相关的python扩展,但是对django的语法提示并不是太友好,这可能是文本编辑器最大的伤。
(2)推荐使用pycharm。具体下载地址网上很多。
第三步:Django开发app
1、创建自己的项目,程序员的入门helloworld,使用django-admin工具进行项目创建。
django-admin startproject HelloWorld
2、创建应用,比如polls:
django-admin startapp Polls
此时的文件目录结构如下:
2.1 文件介绍:
settings.py 是对整个项目的一些基础设置,我用到的有如下部分
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'polls', #把新建的polls应用添加到apps列表
]
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
#'django.middleware.csrf.CsrfViewMiddleware', 注释掉csrf,防止在post请求时出现问题
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [BASE_DIR+"/templates"], #设置模板目录,目录可以看文件夹结构
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 或者使用 mysql.connector.django
'NAME': 'test',
'USER': 'root',
'PASSWORD': 'aa',
'HOST':'10.1.1.21',
'PORT':'3306',
}
}
APPEND_SLASH=False #这个主要是为了去掉url里的 / ,比如post请求 http://a.com/haha/,最后面的 / 就可以不需要,变成 http://a.com/haha
2.2 HelloWorld 目录下的urls.py,它是控件整个项目的url入口
#HelloWorld目录下的urls.py
from django.urls import path,include
from django.contrib import admin
from . import view
urlpatterns = [
path('hello/', view.hello),
path('hello1/', view.hello1),
path('polls/', include('polls.urls')), # 这个是加载进来polls目录下的urls.py
path('admin/', admin.site.urls),
]
#Polls目录下的urls.py
from django.urls import path
from . import views
urlpatterns=[
path('haha1',views.index,name='index'),
path("haha/<int:year>/<int:month>/",views.test),
path("postest",views.postindex),
path('hello',views.index,name='hello'),
]
这样,在启动服务时, python manage.py runserver 127.0.0.1:8000 即可启动服务
http://127.0.0.1:8000/hello 的时候,访问的是HelloWorld目录下的view.py的hello方法
http://127.0.0.1:8000/polls/hello 的时候,访问polls文件夹下view.py的index方法
http://127.0.0.1:8000/polls/haha/2/3 的时候,会返回数值5
3. get和post请求的数据处理,以入orm查询的一些方法
在orm查询的时候,要注意model的写法。
django的model,如果不指定pk,会自动设置一个自增id列,并设为pk,这样你原来存在的表里没有id列就会有问题。
#polls目录下的model.py
from django.db import models
# Create your models here.
class DyjgModel(models.Model):
tjcode=models.CharField(max_length=255,verbose_name='机构代码',primary_key=True)
tjname=models.CharField(max_length=255,verbose_name='机构名称')
type=models.CharField(max_length=255)
city=models.CharField(max_length=255)
town=models.CharField(max_length=255)
jglevel=models.CharField(max_length=255)
contactname=models.CharField(max_length=255)
tjadress=models.CharField(max_length=255)
tjphone=models.CharField(max_length=255)
class Meta:
verbose_name = verbose_name_plural = ""
db_table='dy_jg'
#polls目录下的views.py
from django.shortcuts import render
from django.db import connection
import MySQLdb
import json
from django.core.serializers import serialize
# Create your views here.
from django.http import HttpResponse
from polls.models import DyjgModel
#orm查询,返回json格式
def index(request):
rows = DyjgModel.objects.values("tjcode","tjname")
rows = list(rows)
rows = json.dumps(rows)
return HttpResponse(rows)
#orm查询字段,渲染页面,并遍历输出
def index3(request):
rows = DyjgModel.objects.values_list('tjcode','tjname')
context={}
context['tags']=rows
#return HttpResponse(rows);
return render(request, 'index.html',context);
def test(request,month,year):
return HttpResponse(month+year);
#生成字典格式方法
def dictfetchall(cursor):
desc = cursor.description
return [
dict(zip([col[0] for col in desc], row))
for row in cursor.fetchall()
]
#原生写法,返回字典格式
def index1(request):
cursor = connection.cursor();
cursor.execute("select * from dy_jg",None);
rows = dictfetchall(cursor)
return HttpResponse(rows)
#return render(request, 'index.html',context);
#返回json格式
def indexjson(request):
cursor = connection.cursor();
cursor.execute("select * from dy_jg",None);
rows = dictfetchall(cursor)
print(rows)
return HttpResponse(json.dumps(rows))
def postindex(request):
print(request.method)
return HttpResponse("haa")
目前来看,get和post请求都已测试通过,并且对返回的数据,进行了json转换(为后台服务api作准备),通过原生查询(面对一些非常复杂查询时)、orm查询都进行了实现,为以后的开发做一些技术准备。