Django 博客教程:建立django工程(连载二)
專 欄
❈追梦人物,电子科技大学计算机学院研究生,从事大数据分析研究方向。主要使用 Python 语言进行相关数据的分析,熟练使用 django 开发网站系统。Django开源论坛作者。
博客地址:http://www.jianshu.com/u/f0c09f959299
❈
建立 django 工程
万事已经具备了,让我们来建立我们的 django 工程。 django 工程(project)是我们项目代码的容器。例如我们博客项目中所有的代码(包括 django 为我们自动生成的以及我们自己写的)都包含在这个工程里,说白了就是用一个文件夹包起来的一系列 Python 代码文件和 django 配置文件。但我们不必去亲自动手新建这个文件夹和代码文件,django 的命令帮我们做了这些事情。例如我把博客项目工程的代码放在 C:UsersyangxgWorkspace ,工程名我把它叫做 blogproject ,那么首先在命令行工具进入 C:UsersyangxgWorkspace 这个目录(如果你还停留在 Python 的命令栏里,先多按几次 ctrl + c
跳出来):
(blogproject_env) C:WINDOWSsystem32>cd C:UsersyangxgWorkspace
然后运行如下命令:
(blogproject_env) C:UsersyangxgWorkspace>django-admin startproject blogproject
再次申明一定要在虚拟环境下运行这些命令,虚拟环境的标志就是命令提示符前有 (blogproject_env) 这样的标记。以后所有的和 django 有关的命令都是在虚拟环境下运行,因此在运行前一定确保先开启了虚拟环境。
进入工程所在目录 C:UsersyangxgWorkspace(你可能设置在其他路径),你会发现多了一个名为 blogproject 的文件夹,其内部文件结构如下:
blogproject /
manage.py
blogproject /
__init__.py
settings.py
urls.py
wsgi.py
最顶层的 blogproject/ 目录是我们刚刚指定的工程目录,其下面有一个 manage.py 文件,manage 是管理的意思,顾名思义 manage.py 就是 django 为我们生成的管理我们这个项目的 Python 脚本文件,以后用到时会再次介绍。与 manage.py 同级的还有一个名为 blogproject 的文件夹,这里面存放了一些 django 的配置文件,例如 settings.py 等等,以后用到时会详细介绍。此外,其下面的 __init__.py 指明了这是一个 Python 模块包。Python 规定在一个文件夹里包含 __init__.py 文件来指明这是一个 Python 模块包,这样你就可以在别的 Python 代码中引入它。
Hello django
网站需要运行在一个 web 服务器上,django 已经为我们提供了一个用于本地开发的 web 服务器。在命令行工具里进入到 manage.py 所在目录,运行下面的命令就可以在本机上开启一个 web 服务器:
(blogproject_env) C:UsersyangxgWorkspace>cd C:UsersyangxgWorkspaceblogproject
(blogproject_env) C:UsersyangxgWorkspaceblogproject>python manage.py runserver
Performing system checks...
System check identified no issues (0 silenced).
You have 13 unapplied migration(s). Your project may not work properly until you apply the migrations for app(s): admin, auth, contenttypes, sessions.
Run 'python manage.py migrate' to apply them.
December 21, 2016 - 20:23:07
Django version 1.10.4, using settings 'blogproject.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.
看到这样的信息表明我们的服务器开启成功,在浏览器输入http://127.0.0.1:8000/ ,看到如下的页面提示信息:
> # It worked!
>
> ## Congratulations on your first Django-powered page.
>
> Of course, you haven't actually done any work yet. Next, start your first app by running `python manage.py startapp [app_label]`.
>
> You're seeing this message because you have `DEBUG = True` in your Django settings file and you haven't configured any URLs. Get to work!
It worked! django 工作了!一切准备就绪,开始进入我们的 django 博客开发之旅了!
注:这是 manage.py 的第一个用法,运行它的 runserver 命令开启本地开发服务器,以后还会遇到更多的命令。
命令栏工具下按 Ctrl + c 可以退出开发服务器(按一次没用的话连续多按几次)。重新开启则再次运行 `python manage.py runserver`
另外我们 django 默认的语言是英语,所以显示给我们的欢迎页面是英文的。我们在 django 的配置文件里稍作修改,让它支持中文。用任何一个文本编辑器打开 settings.py 文件,找到如下的两行代码:
```python
blogproject/blogproject/settings.py
<div class="md-section-divider"></div>
## 其它配置代码...
LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC'
<div class="md-section-divider"></div>
## 其它配置代码...
<div class="md-section-divider"></div>
把 LANGUAGE_CODE
改为 zh-hans
,TIME_ZONE
改为Asia/Shanghai
:
blogproject/blogproject/settings.py
<div class="md-section-divider"></div>
# 其它配置代码
LANGUAGE_CODE = 'zh-hans' # 把英文改为中文
TIME_ZONE = 'Asia/Shanghai' # 把国际时区改为中国时区
<div class="md-section-divider"></div>
# 其它配置代码
<div class="md-section-divider"></div>
再次运行开发服务器,并在浏览器打开 http://127.0.0.1:8000/,可以看到 django 已经支持中文了。
(blogproject_env) C:UsersyangxgWorkspaceblogproject>python manage.py runserver
Performing system checks...
<div class="md-section-divider"></div>
> # 正常工作了!
>
> ## 祝贺你的第一个由Django驱动的页面。
>
> 当然,您还没有真正开始工作。接下来,请执行 `python manage.py startapp [app_label]` 来创建您的第一个应用。
>
> 您看到此消息是由于Django的配置文件设置了 `DEBUG = True`,您还没有配置任何路由URL。开始
版权声明
本作品采用知识共享署名-非商业性使用-禁止演绎 3.0 中国大陆许可协议进行许可。
- ASP.NET MVC HandleErrorAttribute 和 远程链接
- javascript实现数字转大写金额的函数
- 如何在GridView的Footer内显示总计?
- 自定义WCF的配置文件
- Centos中动态扩容lvm逻辑卷的操作记录
- Visual Round Trip Analyzer
- ASP.NET可以在Windows Server 2008 R2 Server Core上运行
- SOA十大设计原则
- 中国人民大学文继荣:大数据的经验主义解释
- 检查Python对象
- 分布式监控系统Zabbix-3.0.3-完整安装记录(6)-微信报警部署
- Android 命名规范 (提高代码可以读性)
- Msdn 杂志 asp.net ajax 文章汇集
- 分布式监控系统Zabbix-3.0.3-完整安装记录-新报微信报警(企业微信)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- dotnet OpenXML 元素 cNvPr NonVisual Drawing Properties 重复 id 标识处理
- Magicodes.IE之花式导出
- vue列表点击切换颜色
- JVM加载过程科普
- 我没学过计算机,是怎么接了四个私活还挣了两个 iPad 的?
- Helm安装Prometheus Operator
- 【每日一题】【vue2源码学习】vue如何检测数组的变化
- JavaScript 实现输入框内容一键复制(附上 Vue 3 实现方式)
- python 迭代器/iterator与生成器/generator的区别
- CSS 实现文本超出容器范围用省略号显示(单行+多行)
- ESP8266和ROS收发消息读取模拟量控制LED亮度
- 纯 CSS 实现下拉菜单尖角图标(实心+空心)
- 3分钟短文:书接上回,Laravel数据库迁移的那些个小技巧
- 解密 Docker 挂载文件,宿主机修改后容器里文件没有修改
- SAP Spartacus的单元测试目录结构