Python web开发django第一周学习汇总

第一步:安装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查询都进行了实现,为以后的开发做一些技术准备。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值