Python笔记之Django

本文详细介绍Django框架的安装步骤,包括工程与应用的创建、服务器启动、管理员账户设置及中文环境配置。涵盖数据库连接与常见问题解决,如Mysql数据库连接配置及误删migration文件后的恢复方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

安装Django

pip install django

新建工程

cd至要新建工程的目录下,执行

django-admin startproject 工程名

会自动生成一个与工程名同名的文件夹。

启动服务器

cd至项目目录,执行python manage.py runserver
服务器就启动了,默认情况下地址为127.0.0.1:8000
Ctrl+CCtrl+Break关闭。

创建管理员账户

manage.py createsuperuser

后台管理改为中文

settings.py调整如下:

LANGUAGE_CODE = 'zh-hans'

TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_L10N = True

USE_TZ = False

app流程

  1. python manage.py startapp 应用名
  2. 添加到settings.py的INSTALLED_APPS
  3. 编写models.py
from django.db import models
 
 # Create your models here.
 
 
class Provider(models.Model):
	name = models.CharField(max_length=50, verbose_name="供方名称")
 
	class Meta: #表单名称
		verbose_name = "供方"
		verbose_name_plural = verbose_name
 
	def __str__(self): #默认返回名称,便于显示
		return self.name
 
 
class Product(models.Model):
	name = models.CharField(max_length=50, verbose_name="产品名称")
	type = models.CharField(max_length=50, verbose_name="产品型号")
	provider = models.ForeignKey(Provider, on_delete="CASCADE", verbose_name="供方")
 
	class Meta:
		verbose_name = "产品"
		verbose_name_plural = verbose_name
 
	def __str__(self):
		return self.name
  1. python manage.py makemigrations 应用名
  2. python manage.py migrate 应用名

连接Mysql数据库

  1. pip install mysqlclient
  2. 用Mysql客户端建立数据库
  3. 修改settings.py
DATABASES = {
    'default': {
        #'ENGINE': 'django.db.backends.sqlite3',
        #'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
        'ENGINE': 'django.db.backends.mysql', #数据库的类型  
        'NAME': 'depot', #所使用的的数据库的名字
        'USER': 'root', #数据库服务器的用户  
        'PASSWORD': 'root',   #密码  
        'HOST': 'localhost', #主机  
        'PORT': '3306',   #端口        
    }
}

常见问题

误删migration目录下的py文件

备份数据库,把所有app的migrations目录全部清空(注意保留__init__.py文件),重新运行makemigrations以及migrate
参考链接:https://www.jianshu.com/p/806bce409673

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值