Django 开发项目是很快的,有多快?看完本篇文章,你就知道了。
安装 Django
前提条件:已安装 Python。
Django 使用 pip 命令直接就可以安装:
pip install django
如果安装失败,很可能是因为网络连接超时了,试试国内镜像:
pip install --default-timeout=6000 -i https://pypi.tuna.tsinghua.edu.cn/simple django
这条命令同时延长了超时时间,提高成功率。
安装完成后,通过 django-admin --version
这条命令验证。
创建 project
按住 Windows 键 + R,输入 cmd 回车,接着 cd 到任意目录:
或者先打开目录窗口,在地址栏输入 cmd 回车,不需要 cd(推荐):
在命令行窗口输入命令创建 project:
django-admin startproject mysite
目录结构如下(注意有 2 个 mysite 哦):
mysite/ manage.py mysite/ __init__.py settings.py urls.py asgi.py wsgi.py
创建 app
Django 项目由 1 个 project 和多个 app 组成。project 存放项目配置,app 是网站各个功能的具体实现。
app 的放置目录没有限制,这里先放在和 mysite 的同级目录中,先进入外层的 mysite 文件夹:
cd mysite
输入命令创建:
django-admin startapp polls
目录结构如下:
mysite/ polls/ __init__.py admin.py apps.py migrations/ __init__.py models.py tests.py views.py mysite/ manage.py
使用 cmd 创建完 project 和 app 以后,就可以打开 PyCharm,再 Open mysite 项目了:
为了让 app 和 project 关联起来,需要在 mysite/settings.py 文件中添加配置:
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'polls.apps.PollsConfig', # 添加 ]
在 polls/models.py 文件中添加数据模型:
from django.db import models class Question(models.Model): question_text = models.CharField(max_length=200) pub_date = models.DateTimeField('date published') class Choice(models.Model): question = models.ForeignKey(Question, on_delete=models.CASCADE) choice_text = models.CharField(max_length=200) votes = models.IntegerField(default=0)
连接 MySQL
前提条件:已安装 MySQL,创建好数据库。
Django 默认使用轻量级数据库 SQLite,我们切换为常用的 MySQL。
修改 mysite/settings.py 中的数据库配置:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'HOST': '主机', 'PORT': 端口, 'NAME': '数据库名', 'USER': '用户名', 'PASSWORD': '密码' } }
Django 默认通过底层调用 mysqlclient 这个库和 MySQL 交互。但是 mysqlclient 非常不好安装!我们改用 pymysql。
先安装:
pip install pymysql
然后在与 mysite/settings.py 文件同级的 __init__
文件中添加:
import pymysql pymysql.version_info = (1, 4, 0, "final", 0) pymysql.install_as_MySQLdb()
数据迁移
数据迁移,指的是把代码中的数据模型,迁移到数据库中,创建相应的表结构。
第一步,告诉 Django 数据模型有更新:
python manage.py makemigrations polls
执行后输出:
Migrations for 'polls': polls/migrations/0001_initial.py - Create model Question - Create model Choice
第二步,执行数据迁移同步:
python manage.py migrate
执行后输出:
Operations to perform: Apply all migrations: admin, auth, contenttypes, polls, sessions Running migrations: Rendering model states... DONE Applying polls.0001_initial... OK
数据库表就创建好了:
启动项目
万事俱备,只差 1 条启动命令,在根目录执行:
python manage.py runserver
访问 http://127.0.0.1:8000/,就可以看到来自 Django 老铁的这发火箭了:
小结
本文是对《匆匆一眼》文章的补充。介绍了如何安装 Django,创建 Django 的 project 和 app,连接 MySQL,执行数据迁移,最后启动项目的实际操作步骤。思路很清晰。整体流程清楚了,可这些文件都是干嘛的呢?
参考资料:
https://docs.djangoproject.com/en/3.1/intro/tutorial01/
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】
- 林俊吉.2012-将你惜命命【美华】【WAV+CUE】
- 晓雅《分享》DTS-WAV
- 黑鸭子2008-飞歌[首版][WAV+CUE]
- 黄乙玲1989-水泼落地难收回[日本天龙版][WAV+CUE]
- 周深《反深代词》[先听版][FLAC/分轨][310.97MB]
- 姜育恒1984《什么时候·串起又散落》台湾复刻版[WAV+CUE][1G]
- 那英《如今》引进版[WAV+CUE][1G]
- 蔡幸娟.1991-真的让我爱你吗【飞碟】【WAV+CUE】
- 群星.2024-好团圆电视剧原声带【TME】【FLAC分轨】