python+Django+postgresql 的web开发实例--杰西笔记

--------

新建Django项目  




选择sqlite数据库

2.创建模块app

3.测试新建的模块是否正常

Validating models...0 errors found
March 12, 2014 - 10:26:53
Django version 1.6.2, using settings 'mysite.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.

服务器启动起来后,去浏览器输入网址:http://127.0.0.1:8000,你会看到 “Welcome to Django” 页面。

表示它已正常工作!

让我们来看看mysite都创建了些什么:

这些文件分别是:
a、外层mysite目录只是你项目的一个容器。对于Django来说该目录名并不重要;你可以重命名为你喜欢的。
b、manage.py: 一个实用的命令行工具,可让你以各种方式与该Django项目进行交互。 
c、内层mysite目录是你项目中的实际Python包。该目录名就是Python包名,通过它你可以导入它里面的任何东西。(e.g.import mysite.settings).
d、mysite/__init__.py:一个空文件,告诉Python该目录是一个Python包。 
e、mysite/settings.py:该Django项目的设置/配置。 
f、mysite/urls.py:该Django项目的URL声明;一份由Django驱动的网站“目录”。 
g、mysite/wsgi.py:一个WSGI兼容的Web服务器的入口,以便运行你的项目。

更改端口号
默认情况下,:djadmin:runserver 命令启动的开发服务器只监听本地IP的8000端口。

如果你想改变服务器的端口,把它作为一个命令行参数传递即可。例如以下命令启动的服务器将监听8080端口:

C:\Users\D-117>cd F:\workspace\mysite\src\mysite\ #manage.py文件所在目录,即mysite项目下
C:\Users\D-117>f:
F:\workspace\mysite\src\mysite>python manage.py runserver 8080
Validating models...0 errors found
March 12, 2014 - 10:31:27
Django version 1.6.2, using settings 'mysite.settings'
Starting development server at http://127.0.0.1:8080/
Quit the server with CTRL-BREAK.

如果你想改变服务器IP,把它和端口号一起传递即可。因此,要监听所有公共IP地址(如果你想在其他电脑上炫耀你的工作),请使用:
python manage.py runserver 0.0.0.0:8000

数据库设置
现在,编辑 mysite/settings.py 。 这是一个普通的Python模块,包含了代表Django设置的模块级变量。 更改DATABASES中'default'下的以下键的值,以匹配您的数据库连接设置。
a、ENGINE – 从 'django.db.backends.postgresql_psycopg2', 'django.db.backends.MySQL', 'django.db.backends.sqlite3', 'django.db.backends.Oracle' 中选一个
b、NAME – 你的数据库名。如果你使用 SQLite,该数据库将是你计算机上的一个文件;在这种情况下,:setting:NAME 将是一个完整的绝对路径,而且还包含该文件的名称。如果该文件不 
存在,它会在第一次同步数据库时自动创建(见下文)。当指定路径时,总是使用正斜杠,即使是在Windows下(例如:`C:/homes/user/mysite/sqlite3.db`) 。
c、USER – 你的数据库用户名 ( SQLite 下不需要) 。
d、PASSWORD – 你的数据库密码 ( SQLite 下不需要) 。
e、HOST – 你的数据库主机地址。如果和你的数据库服务器是同一台物理机器,请将此处保留为空 (或者设置为 127.0.0.1) ( SQLite 下不需要) 。 
如果你是新建数据库,我们建议只使用 SQLite ,将 ENGINE 改为 'django.db.backends.sqlite3' 并且将 NAME 设置为你想存放数据库的地方。 SQLite 是内置在 Python 中的,因此你不需要安装任何东西来支持你的数据库。


setting 文件数据库配置PostgreSQL 



注意:
如果你使用PostgreSQL或者MySQL,确保你已经创建了一个数据库。还是通过你的数据库交互接口中的“CREATE DATABASE database_name;”命令做到这一点的。
如果你使用SQLite,你不需要事先创建任何东西 - 在需要的时候,将会自动创建数据库文件。

当你编辑 settings.py 时,将 TIME_ZONE 修改为你所在的时区。默认值是美国中央时区(芝加哥)。同时,注意文件底部的 INSTALLED_APPS 设置。它保存了当前 Django 实例已激活的所 
有 Django 应用。每个应用可以被多个项目使用,而且你可以打包和分发给其他人在他们的项目中使用。

默认情况下,:setting:INSTALLED_APPS 包含以下应用,这些都是由 Django 提供的:

django.contrib.auth – 身份验证系统。
django.contrib.contenttypes – 内容类型框架。
django.contrib.sessions – session 框架。
django.contrib.sites – 网站管理框架。
django.contrib.messages – 消息框架。
django.contrib.staticfiles – 静态文件管理框架。

这些应用在一般情况下是默认包含的。

所有这些应用中每个应用至少使用一个数据库表,所以在使用它们之前我们需要创建数据库中的表。要做到这一点,请运行以下命令:python manage.py syncdb,具体操作下面会阐述。

至此,项目开发环境建立好了,我们可以开工了。

二、创建模型

4.编辑代码
4.1修改blog.models.py

from django.db import models
from django.contrib import admin# Create your models here.
class BlogPost(models.Model):title = models.CharField(max_length = 150)content = models.TextField()timestamp = models.DateTimeField()class BlogPostAdmin(admin.ModelAdmin):list_display = ('title', 'content', 'timestamp')admin.site.register(BlogPost, BlogPostAdmin)

我们将创建一个BlogPost模型,包含title、content、timestamp三个字段。每个模型都继承自django.db.models.Model子类的类来描述。 每个模型 
都有一些类变量,每一个类变量都代表了一个数据库字段。

每个字段由一个 Field 的实例来表现 – 比如 CharField 表示字符类型的字段和 DateTimeField 表示日期时间型的字段。这会告诉 Django 每个 
字段都保存了什么类型的数据。

每一个 Field 实例的名字就是字段的名字(如: title、content、timestamp),其格式属于亲和机器式的。在你的 Python 的代码中会使用这个 
值,而你的数据库会将这个值作为表的列名。

4.2修改blog.views.py

# Create your views here.
from django.template import loader,Context
from django.http import HttpResponse
from blog.models import BlogPostdef archive(request):posts = BlogPost.objects.all()t = loader.get_template('archive.html')c = Context({'posts': posts})return HttpResponse(t.render(c))

4.3修改mysite.setting.py,找到下面部分进行修改

INSTALLED_APPS = ('django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','blog',
)

4.4修改mysite.urls.py

from django.conf.urls import patterns, include, urlfrom django.contrib import admin
admin.autodiscover()from blog.views import archiveurlpatterns = patterns('',# Examples:# url(r'^$', 'mysite.views.home', name='home'),# url(r'^blog/', include('blog.urls')),url(r'^admin/', include(admin.site.urls)),url(r'^blog/', archive),
)

5.建立样式网页模板
请在包blog下添加templates文件夹,并在templates下建立两个网页文件:archive.html和base.html

5.1编辑archive.html

{% extends "base.html" %}  
{% block content %}  
{% for post in posts %}  
<h1>{{ post.title}}</h1>  
<p>{{ post.content }}</p>
<p>{{ post.timestamp|date:"1, F jS"}}</p>
{% endfor %}  
{% endblock %}

5.2编辑base.html

<html>  <style type="text/css">  body { color: #edf; background: #453; padding: 0 5em; margin:0 }  h1 { padding: 2em lem; background:#675 }  h2 { color: #bf8; border-top: 1px dotted #fff; margin-top: 2em }  p { margin: lem 0 }  </style>  <body>  <h1><center>Alexia's Blog</center></h1>  {% block content %}  {% endblock %}  </body>  
</html>

三、同步数据库


当我做到这一步  控制台报错了

当我做到这一步 输入yes 的时候,控制台报错了 ,找了半天不知道原因 各种百度搜索 终于找到最终原因

 Superuser creation skipped due to not running in a TTY. You can run `manage.py createsuperuser` in your project to create one manually. Finished "C:\Users\lucifer\Python_\mysite\src\manage.py syncdb" execution.

  原来eclipse同步数据库出错了 需要在cmd里面创建,步骤 :

打开cmd cd到项目的路径 :如我的项目manage.py cd 所在的路径是: C:\Users\lucifer\Python_\mysite\src

输入 python manage.py syncdb 命令 数据库建表成功建表之后需要让你输入之前在setting文件设置的用户名和密码 还有邮箱地址




运行测试

登陆界面,登陆账号和密码是初始化数据库的时候设定的。

登录成功后跳转到下面页面:

在该页面可以添加blog文章 :


发布成功后,输入网址:http://127.0.0.1:8000/blog/进行查看,是否测试成功!

楼主测试时候遇到这个问题  :


原来是templates 在eclipse放错位置了 

 应该templates放blog里面才对 



输入网址:http://127.0.0.1:8000/blog/进行查看,测试成功!



以上内容希望对你有帮助!! 作者 Won_h

更多精彩内容,请点微博短链看新浪博客原文
生成长微博

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/19735.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端开发 20 年变迁史

1、引言 1990 年&#xff0c;第一个Web浏览器的诞生&#xff1b;1991 年&#xff0c;WWW诞生&#xff0c;这标志着前端技术的开始。 在这将近20年的前端发展史中&#xff0c;我们经历了从最早的纯静态页面&#xff0c;到JavaScript跨时代的诞生&#xff1b;从PC端到移动端&am…

毕业5年,我把前后端好的书籍整理了一下,希望能帮到你(建议收藏)

点赞再看&#xff0c;养成习惯&#xff0c;微信搜索【三太子敖丙】我所有文章都在这里&#xff0c;本文 GitHub https://github.com/JavaFamily 已收录&#xff0c;有一线大厂面试完整考点&#xff0c;文末有福利。 前言 我们的一生其实也基本上都在学习&#xff0c;那提到学习…

JavaScript 25 岁了!

本文已过原作者授权翻译。 JavaScript于25年前&#xff08;1995年12月4日&#xff09;首次向公众推出。JavaScript 最初开发仅用了10天时间&#xff0c;便迅速成为最受欢迎的编程语言之一&#xff0c;如今全球有数百万的开发人员每天都在使用它。 2020年是它的25周年纪念日——…

北四环的杰西·利弗莫尔:一个中国投机客的传说

本文转自偏见实验室 作者 周玉梅 火车疾驰而来&#xff0c;大多数人站在铁轨上&#xff0c;你是其中之一&#xff0c;此时要不要躲开&#xff1f; 这可能是人类历史上最难解的谜团之一。它是如此简单&#xff0c;大多数人都知道正确答案&#xff0c;它同时又如此艰难&#xff…

杰西·李佛摩尔的股市存亡战

本文转自微信公众号格上私募圈&#xff08;ID&#xff1a;simuquan) 作者&#xff1a;黑猫 李佛摩尔的投资存亡战——操盘伯利恒钢铁 一颗子弹、一次机会&#xff0c;破产地狱或资本天堂&#xff01; 本文是为了忘却的纪念: 杰西李佛摩尔大师的股市生存战“操盘伯利恒钢铁”…

有一群志同道合的程序员朋友是怎样的体验?

老粉看下面这张照片应该有点眼熟&#xff0c;这是去年年底跟杭州几个朋友聚会的照片&#xff0c;当时我还水了一篇文章。时隔一年&#xff0c;今天另一个朋友的房子也交付了&#xff0c;我们每年在一个人新家里聚餐的传统又延续了下来。 照片里的这些朋友都是我来杭州之后认识的…

前端简史之裂变:Ajax变法

引 &#x1f4a1; 知来处&#xff0c;明去处。了解一门技术的历史&#xff0c;可以帮助我们从历史的角度上去理解这门技术背后的原理&#xff0c;知道这门技术为什么会产生&#xff0c;为什么会变成现在这个样子&#xff0c;它未来的一个发展趋势又是什么样的。 课程简介 《前…

“她”和“杰西”:虚拟助手的机器人魅力

Over the years — usually courtesy of bizarre Channel 4 documentaries — I’ve heard about people falling in love with all sorts of weird and wonderful things. 版本岁月-通常是礼貌离奇4频道的纪录片-我听说过的人爱上了各种各样的神秘和奇妙的事情 。 Some of th…

投机之王杰西·利弗莫尔的经典炒股语录

1、优秀的投机家们总是在等待&#xff0c;总是有耐心&#xff0c;等待着市场证实他们的判断。要记住&#xff0c;在市场本身的表现证实你的看法之前&#xff0c;不要完全相信你的判断。 2、要想在投机中赚到钱&#xff0c;就得买卖一开始就表现出利润的商品或者股票。那些买进…

交易原则Jesse Livermore 杰西·利弗莫尔

交易原则&#xff08;Jesse Livermore 杰西利弗莫尔&#xff09;&#xff1a; https://www.youtube.com/watch?v8cph2_Xvfbo&listPL-c0DN3fTeQcjsrsRJVET4RWLQBQRx_bb&index19&ab_channel%E5%B0%8FLin%E8%AF%B4 1、 2、 1和2本质上都是对抗自己的本能&#xff1…

【深度学习】CVPR 2023论文总结!CV最热领域颁给多模态、扩散模型

编辑&#xff1a;桃子 好困 来源&#xff1a;新智元 【导读】CVPR 2023有哪些亮点&#xff1f;从录用论文中我们又能看到CV领域有哪些趋势&#xff1f; 一年一度的CVPR即将在6月18-22日加拿大温哥华正式开幕。 每年&#xff0c;来自世界各地的成千上万的CV研究人员和工程师聚…

如何彻底隐藏表?

哈喽&#xff0c;哈喽&#xff0c;大家好。我的Edon 最近chatGPT很火&#xff0c;这个AI不光会聊天&#xff0c;还会写论文&#xff0c;写诗词&#xff0c;做PPT&#xff0c;写代码&#xff0c;等等。有些人就开始急了&#xff0c;说现在AI都这么强了&#xff0c;那我们这些码…

人工大模型给VBA纠错实践 大赞

近期想给部门办公软件Excel升级一块产品复验期限预警功能报表&#xff0c;日常我们使用思路是&#xff1a;从Excel中写好数据通过按钮&#xff08;查看报表&#xff09;点击调取宏&#xff08;VBA&#xff09;把数据存储到ACCESS数据库中&#xff0c;需要使用的时候再从数据库中…

基于Bi-LSTM与CRF实现中文命名实体识别任务

一、基于Bi-LSTM与CRF实现中文命名实体识别任务 命名实体识别是指识别文本中具有特定意义的实体&#xff0c;主要包括人名、地名、机构名、专有名词等。本项目实现一个简单的命名实体识别方法&#xff0c;该方法通过BiLSTMCRF模型预测出文本中文字所对应的标签&#xff0c;再根…

前沿技术揭秘:云原生-展望容器、自动化和DevOps的发展趋势

2023年最火热的就是ChatGPT,当然还有5G技术、AI、机器学习、区块链等技术。另外还有一个现象就是网上热点及企业招聘JD&#xff0c;都会出现一个词汇那就是“云原生”。云原生究竟是上帝的宠儿还是时代的骄子呢&#xff0c;我们来盘一盘 1、什么是云原生技术&#xff1f; 云原生…

一键安装langchain-ChatGLM

最近开源大模型层出不穷&#xff0c;非常火爆。好多小伙伴跃跃欲试&#xff0c;但是&#xff0c;大模型本地搭建&#xff0c;就算是只做推理也需要性能强悍的机器&#xff0c;更不要说微调和全参数训练&#xff0c;没有几十万的显卡投入是搞不定的。chatGLM推理可以在cpu上运行…

重磅!GPT-4发布,目前最先进人工智能系统

今天OpenAI发布了GPT-4&#xff0c;ChatGPT Plus订阅用户&#xff08;20美元/月&#xff09;可以使用最新的GPT-4&#xff0c;免费用户不变。 根据OpenAI官方对GPT-4新特性的介绍&#xff0c;这里总结有下面5个特性&#xff1a; GPT-4 可以更准确地解决难题&#xff0c;这要归功…

火爆的GPT-4来了!

3月14日&#xff0c;人工智能公司OpenAI发布了ChatGPT&#xff08;GPT-3.5阶段&#xff09;的升级版GPT-4&#xff0c;让原本已经略显沉寂的ChatGPT话题再次迎来了“爆炸式热议”&#xff0c;毫无悬念地冲上了社交平台热搜。“AI 终将取代人类”、“GPP-4考试能力强国90%的人类…

ChatGPT的公司CEO:Altman 认为的优秀人才品质

Altman 认为的优秀人才品质 Sam Altman认为下面这些是优秀创业者的共有品质: 1 清晰的愿景 能准确地阐明他们在做什么以及原因。如果创业者不能够清晰的阐明,也就没有真正理解自己的创业。在Airbnb申请时,他们做了绝大部人永远不会做的事情——在陌生人的客厅睡充气床。…

Python+Socket实现多人聊天室,功能:好友聊天、群聊、图片、表情、文件等

一、项目简介 本项目主要基于python实现的多人聊天室&#xff0c;主要的功能如下&#xff1a; 登录注册添加好友与好友进行私聊创建群聊邀请/申请加入群聊聊天发送图片聊天发送表情聊天发送文件聊天记录保存在本地中聊天过程中发送的文件保存本地 二、环境介绍 python3.8my…