首页 > 编程语言 >Python基础day54 Django2

Python基础day54 Django2

时间:2023-07-27 19:33:06浏览次数:49  
标签:username Python db Django2 django models password day54 conn

配置文件的介绍

# 注册应用的
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'app01.apps.App01Config',
]

################中间件#############################################################
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
################中间件#############################################################
ROOT_URLCONF = 'day54_dj.urls' # 根路由的文件名

#######Django连接MySQL数据库的
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

LANGUAGE_CODE = 'zh-hans' 
TIME_ZONE = 'Asia/Shanghai'

静态文件的配置

# 以登录功能为例

<form action="">
    action参数的三种情况:
        1. 什么都不写,就是朝当前地址提交数据
        2. 要么全写:http://127.0.0.1:8000/login/?username=&password=
        3. 只写后缀
            http://127.0.0.1:8000/login/
"""
    我们知道静态模板文件都是放在templates文件夹中,如果没有这个文件夹就自己创建
    我们一般把静态文件放在static文件夹中,  但是,需要我们自己手动创建出来这个文件夹
    静态文件:
        网站使用的CSS文件
        网站使用的js文件
        网站使用图片
        网站使用的第三方库文件
            jQuery、bootstrap等
            
"""

# 我们还可以针对不同的功能对static文件夹里面的问价进行拆分
css
js
img
...

# 看起来是对的,但是不能访问到
http://127.0.0.1:8000/static/bootstrap-3.4.1-dist/js/bootstrap.min.js 

# 你之前访问的地址都可以访问到,那是因为你在后端开设了可以访问的接口(理由)
# 之所以你现在访问不到刚才的地址,是因为你在后端没有开设这样的一个可访问的接口(路由)

# Django自动的帮我们写好了这样的接口

# 访问静态文件的令牌,以后你只要访问静态文件的路径,就要以/static/开头
STATIC_URL = '/vxcvxcvxcvxcvcx/'  # 静态文件

STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static')
]

# 动态解析路径

{% load static %}

<script src="{% static 'js/jquery.min.js' %}"></script>
<link rel="stylesheet" href="{% static 'bootstrap-3.4.1-dist/css/bootstrap.min.css' %}">
<script src="{% static 'bootstrap-3.4.1-dist/js/bootstrap.min.js' %}"></script>

request对象请求方法

    if request.method == 'POST':
    # if request.method == 'GET':
        # 如何接受post提交过来的数据?
        print(request.POST)  # <QueryDict: {'username': ['asd'], 'password': ['dsa']}>
        print(request.POST.get('username'))  # zfq
        # print(request.GET)  # <QueryDict: {'username': ['ASD'], 'password': ['SDA']}>
        # print(request.GET.get('username'))  # ASD

pycharm连接数据库

pycharm它也支持连接数据,Navicat连接数据库,大多数都是使用Navicat

Django连接MySQL

# 默认情况sqlite3
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

# 连接MySQL

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

# 解决bug的思路:
1. 就是print()
2. 看是否有日志
3. 看报错的信息去百度中搜索
4. 问问别人

# 连接MySQL数据的时候可能报错的解决办法:
1. 如果解释器版本导致的问题,直接改源码
def get_new_connection(self, conn_params):
    conn = Database.connect(**conn_params)
    conn.encoders[SafeText] = conn.encoders[six.text_type]
    # 先判断bytes是否存在于编码器中,如果在才执行操作
    if bytes in conn.encoders: # 加上这句话
        conn.encoders[SafeBytes] = conn.encoders[bytes]
    return conn

2. 解释器版本改为3.6的时候也会报错
Django的底层默认使用的是mysqldb模块,这个模块兼容性很差
# 我们还使用pymysql连接mysql,你要提前安装pymysql模块
Did you install mysqlclient or MySQL-python?

# 怎么解决这个问题:
在项目的任意的__init__.py中加入下面两行代码
*****************************************************************************
import pymysql
pymysql.install_as_MySQLdb()  # 猴子补丁
# 这两行代码的意思就是把底层的mysqldb模块换成pymysql
*****************************************************************************

3. 除了使用mysqldb、pymysql之外还可以使用mysqlclient这个模块
# 你用了mysqlclient这个模块,就不用加上面那两句话了
# mysqlclient安装的时候可能会报各种错误

DATABASES = {
    # 'default': {
    #     'ENGINE': 'django.db.backends.sqlite3',
    #     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    # }

    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'db9',
        'HOST': '127.0.0.1',
        'PORT': 3306,
        'USER': 'root',
        'PASSWORD': 'root',
        'CHARSET': 'utf8'
    }
}

Django中的ORM

什么是ORM:对象映射模型
# 以后在django中写根数据库相关的代码时候,就不用再写原生的SQL语句了,直接通过python代码来操作数据的增删改查.

# orm的书写位置:在models.py中书写
# 概念
表                >>>>>     类名

记录                >>>>>    对象

字段                >>>>>    属性

# 创建出来一张表来
# 所有的类必须继承models.Model
class User(models.Model):  # 表名
    # id int primary key auto_increment
    id = models.AutoField(primary_key=True)
    # username varchar(64)
    username = models.CharField(max_length=64)
    # password varchar(64)
    password = models.CharField(max_length=64)
    
# 类写完之后,一定要做数据库迁移,真正的在数据库中生成表
********************************************************************************
    python36 manage.py makemigrations  # 它的作用是把数据库的迁移记录保存下来
    python36 manage.py migrate           # 才是真正的把数据表创建出来
********************************************************************************

ORM增删改查字段

class Author(models.Model):
    # 如果创建的表中有主键字段,并且主键字段的名字也叫id,那么可以直接省略id字段,会自动创建id字段。
    name = models.CharField(max_length=64)
    password = models.CharField(max_length=64, default=None)  # 增加字段,默认值可以为空或者其他
    password1 = models.CharField(max_length=64, default=None)  # 修改字段,直接修改
    '''删除字段:直接注释掉或者删掉你需要删除的字段代码就好'''

ORM增删改查数据

# 如何查询  select * from author where username = jack and password = 123
# odjects: 小组件,里面封装了很多的方法
# res = models.Author.objects.filter(name=username, password=password).all()  # 查询全部 默认and查询
# res = models.Author.objects.filter(name=username, password=password).first()  # 查询第一条 默认and查询
# res=models.Author.objects.filter(name=username).filter(password=password)# 是and查询
res = models.Author.objects.create(name=username, password=password)  # 往数据库中增加数据
# print(res)
# print(res[0].name)
# print(res[0].password)

 

标签:username,Python,db,Django2,django,models,password,day54,conn
From: https://www.cnblogs.com/zfq132/p/17585851.html

相关文章

  • python学习_列表
    一、为什么需要列表变量可以存储一个元素,而列表是一个"大容器",可以存储N多个元素,且元素可以是不同的类型,程序可以很方便的对这些数据进行整体操作列表相当于其他语言中的数组列表索引示意图:二、列表的创建列表使用中括号即可创建,列表中的不同元素之间使用英文的逗号进行......
  • android studio 如何调用python
    如何在AndroidStudio中调用Python概述:在AndroidStudio中调用Python可以帮助我们解决一些实际问题,比如使用Python的强大数据处理和分析库,或者直接调用已有的Python脚本。本文将介绍如何在AndroidStudio中调用Python,并提供一个示例来解决一个实际问题。步骤:以下是在AndroidSt......
  • python 分割字符
    #输入王小明,输出王小明#读取原始txt文件withopen('D:\\PCCW_Test_Script\\111.txt',encoding='utf-8')asfile1:content=file1.readlines()#print(content)withopen('D:\\PCCW_Test_Script\\222.txt',"w",encoding=......
  • github源码python如何运行
    如何运行GitHub上的Python源码项目问题描述GitHub上有很多优秀的Python源码项目,但是对于一些新手来说,如何正确地运行这些项目可能会成为一个问题。因此,本文将提供一份解决方案,以帮助新手顺利地运行GitHub上的Python源码项目。解决方案步骤1:克隆项目首先,在GitHub......
  • Python @classmethod decorator and static method All In One
    Python@classmethoddecoratorandstaticmethodAllInOne修饰器/装饰器;静态方法;实例方法#clsclassRectangle:def__init__(self,width,height):self.width=widthself.height=height#实例方法defcalculate_area(self):returnself.wid......
  • python使用ctypes调用gcc编译的dll之ctypes的使用
    简介ctypes是Python的外部函数库。它提供了与C兼容的数据类型,并允许调用C或C++编译后的DLL或共享库中的函数。可使用该模块以纯Python形式对这些库进行封装。本例中代码基于window系统,python为64位3.9.12,如需在liunx上使用请参考上篇博客1、代码的基础结构如下1.1新......
  • Python数据可视化-折线图
    Python数据可视化-折线图一、JSON数据格式1.1什么是jsonJSON是一种轻量级的数据交互格式。可以按照JSON指定的格式去组织和封装数据JSON本质上是一个带有特定格式的字符串主要功能:json就是一种在各个编程语言中流通的数据格式,负责不同编程语言中的数据传递和交互1.2json......
  • python 日志
    #coding:utf-8importloggingimportsysimportosimportdatetimefromloggingimporthandlersclassLogger(object):def__init__(self,name):LOGGING_TO_CONSOLE=TrueLOGGING_LEVEL=logging.DEBUGLOGGING_FORMATTER='%(asc......
  • python使用多进程multiprocessing执行报错
        inthemainmodule:      if__name__=='__main__':        freeze_support()        ...    The"freeze_support()"linecanbeomittediftheprogram    isnotgoingtobefrozentop......
  • 一个能提高写代码效率的方法:AI+Python
    ​ 在今年之前,我们都以为AI只能取代底层的劳动密集型工作,涉及创意、思维和感情的工作是不会被AI取代的,但自今年年初,人工智能异军突起狠狠将我们打脸。 今年火爆的聊天机器人仅仅作为“弱人工智能”,就让大批翻译、文案、设计、程序员等行业人员瑟瑟发抖,各路专家认为,未来人工......