01.Django学习之安装,建立项目,传参,MySQL数据库,静态文件配置和模板的使用

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 1:安装 pip install Django==1.8.6 2:建立项目  进入某个目录执行 django-admin.py startproject myweb(此为项目目录)  建立子目录:         先进入 myweb目录,然后执行 manage.
1:安装
pip install Django==1.8.6

2:建立项目
 进入某个目录执行 django-admin.py startproject myweb(此为项目目录)

 建立子目录:
        先进入 myweb目录,然后执行 manage.py startapp blog,ok子目录完毕
        在SName的views.py中添加如下代码:
             from django.http import HttpResponse
            def hello(request):
                return HttpResponse("Hello World")


   配置url:
        在myweb的settings.py 中INSTALLED_APP = ('xxxx','xxx','xxx','blog',)加上blog
        在同级目录的urls.py中 配置url,这里有两种方式
            (1)直接定位    url(r'^blog/index/$','blog.views.hello'),
            (2)定位到子目录
                    在myweb 中的urls.py中加入url(r'^blog/', include('blog.urls'))
                 再定位到具体文件
                     在blog中的urls.py中加入url(r'^blog/$', 'blog.views.hello')

     启动服务:
          进入myweb目录,执行manage.py runserver

     浏览器访问:
           127.0.0.1:8000/blog/hello

    至此项目建立已基本完成
    
3:使用模板
    在blog目录下建立templates文件夹,将index.html放入
    blog的views.py修改如下:
        from django.http import HttpResponse
        from django.template import loader,Context
        def hello(request):
                t = loader.get_template('index.html')
                c = Context({})           #用于传参数    
                return HttpResponse(t.render(c))
           浏览器访问: 127.0.0.1:8000/blog/hello



4:配置CSS,js,images.....等静态文件目录
    在FName下建立static目录,将css,images等文件夹拷贝到此目录下
    在FName的settings.py  STATIC_URL = '/static/' 下加上如下文件
    STATIC_ROOT = os.path.join(os.path.dirname(__file__),'../static')
    STATICFILES_DIRS = (
        ('css',os.path.join(STATIC_ROOT,'css').replace('\\','/') ),  
        ('js',os.path.join(STATIC_ROOT,'js').replace('\\','/') ),
        ('images',os.path.join(STATIC_ROOT,'images').replace('\\','/') ),
        ('upload',os.path.join(STATIC_ROOT,'upload').replace('\\','/') ),
    )
    当然这里也可以简化一下,只需要如下的配置也可以:  
STATIC_URL = '/static/'
STATICFILES_DIRS=(
    os.path.join(BASE_DIR,'static')
)
    在模板网页中使用的时候加上/static/  如:
    <link href="/static/css/index.css" rel="styleshet" type="text/css"  />
  其他的如上
 
5:传递参数:
   传递参数类型为:Python的变量,函数,类....
    ({name}):表示变量

6:URL传值(使用正则表达式)
    myweb 项目下的url
    urlpatterns = [
url(r'^admin/', include(admin.site.urls)),
url(r'^blog/',include('blog.urls')),
]
    复制myweb下的url到blog目录下,修改如下
    urlpatterns = [
url(r'^time/$','blog.views.time'),
url(r'^foo/(\d{4})/(\w+)/$','blog.views.foo'),
]


    def time(request):
t = loader.get_template("time.html")
id = request.GET.get("id")
name = request.GET.get("name")
c = Context({"title":"thinkgamer","time":datetime.datetime.now(),"id":id,"name":name})
return HttpResponse(t.render(c))
 
  
    <body>
<p>time is {{ time | date:"Y-m-d"}}</p>
<p>id is {{ id }}</p>
<p>name is {{ name }}</p>
</body>
    方式二:http://127.0.0.1:8000/blog/foo/1234/asdd/
 
 
    def foo(request,p1,p2):
t = loader.get_template("time.html")
c = Context({"title":"thinkgamer","time":datetime.datetime.now(),"id":p1,"name":p2})
return HttpResponse(t.render(c))
 
 
    <body>
<p>time is {{ time | date:"Y-m-d"}}</p>
<p>id is {{ id }}</p>
<p>name is {{ name }}</p>
</body>
    url(r'^foo/(\d{4})/(\w+)/$','blog.views.foo'),

7:MySQL数据库的简单配置
    连接
    myweb中的settings.py
     DATABASES = {
            'default': {
                'ENGINE': 'django.db.backends.mysql',
                'NAME': 'csvt',
                'USER':'root',
                'PASSWORD':'123456',
                'HOST':'',
                'PORT':'',
            }
       }     
 
 
    blog的models.py文件
 
 
        from django.db import models

        class Employee(models.Model):
             name=models.CharField(max_length=20)
     同步数据库
 
 

首先,用下面的命令验证模型的有效性:

     python manage.py validate
        运行下面的命令来生成 CREATE TABLE 语句
     python manage.py sqlall blog
输出的是sql语句,但此时并没有在数据库中创建数据表
     同步数据库
     python manage.py syncdb
     (此时可能会报错,解决办法是:删除blog下的migrations目录,重新执行python manage.py syncdb即可
     反向同步
     python manage.py inspectdb(查看语句) 
 
 
     python manage.py > inspectdb 
> blog/models.py

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
8月前
|
关系型数据库 MySQL 数据库连接
Django数据库配置避坑指南:从初始化到生产环境的实战优化
本文介绍了Django数据库配置与初始化实战,涵盖MySQL等主流数据库的配置方法及常见问题处理。内容包括数据库连接设置、驱动安装、配置检查、数据表生成、初始数据导入导出,并提供真实项目部署场景的操作步骤与示例代码,适用于开发、测试及生产环境搭建。
384 1
|
5月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
567 7
|
5月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
583 11
|
7月前
|
存储 前端开发 应用服务中间件
Django 实战:静态文件与媒体文件从开发配置到生产部署
Django项目中,静态文件(Static Files)和媒体文件(Media Files)是两类不同用途的文件。本文详细介绍了它们的区别、配置方法以及在开发与生产环境中的处理方式,并结合用户头像上传功能进行实战演示,最后讲解了如何通过Nginx或OpenResty部署静态与媒体文件服务。
343 1
|
10月前
|
Ubuntu 关系型数据库 Linux
Linux数据库安装
本文介绍了在CentOS 8.0和Ubuntu 22.04系统上安装、配置和启动MariaDB数据库服务器的详细步骤。包括通过`yum`和`apt`包管理器安装MariaDB服务,启动并检查服务运行状态,设置root用户密码以及连接数据库的基本操作。此外,还展示了如何在Ubuntu上更新软件包列表、安装依赖项,并验证MariaDB的版本和运行状态。通过这些步骤,用户可以成功部署并初始化MariaDB环境,为后续数据库管理与应用开发奠定基础。
481 61
|
9月前
|
SQL 关系型数据库 MySQL
MySQL下载安装全攻略!小白也能轻松上手,从此数据库不再难搞!
这是一份详细的MySQL安装与配置教程,适合初学者快速上手。内容涵盖从下载到安装的每一步操作,包括选择版本、设置路径、配置端口及密码等。同时提供基础操作指南,如数据库管理、数据表增删改查、用户权限设置等。还介绍了备份恢复、图形化工具使用和性能优化技巧,帮助用户全面掌握MySQL的使用方法。附带常见问题解决方法,保姆级教学让你无忧入门!
1185 21
MySQL下载安装全攻略!小白也能轻松上手,从此数据库不再难搞!
|
9月前
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
543 11
|
5月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
430 158
|
5月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
5月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
987 152