zoukankan      html  css  js  c++  java
  • Python & PyCharm & Django 搭建web开发环境

    一、安装软件

    1、安装 Python 2.7、PyCharm、pip(Python包管理工具)、Django ( pip install Django)


    二、部署
    1、PyCharm 新建Django工程
     
     
    完成后,其目录如下:
     
     
    子目录MyDjangoProject下表示工程的全局配置,分别为setttings.py、urls.py和wsgi.py,其中setttings.py包括了系统的数据库配置、应用配置和其他配置,urls.py则
    表示web工程Url映射的配置。
    子目录student则是在该工程下创建的app,包含了models.py、tests.py和views.py等文件
    templates目录则为模板文件的目录
    manage.py是Django提供的一个管理工具,可以同步数据库等等
     
    2、启动
    创建完成后,就可以正常启动了。点击Run 按钮,启动时报错了:
     
     1 Traceback (most recent call last):
     2   File "D:/workspace/MyDjangoProject/manage.py", line 10, in <module>
     3     execute_from_command_line(sys.argv)
     4   File "D:Python27libsite-packagesdjangocoremanagement\__init__.py", line 338, in execute_from_command_line
     5     utility.execute()
     6   File "D:Python27libsite-packagesdjangocoremanagement\__init__.py", line 312, in execute
     7     django.setup()
     8   File "D:Python27libsite-packagesdjango\__init__.py", line 18, in setup
     9     apps.populate(settings.INSTALLED_APPS)
    10   File "D:Python27libsite-packagesdjangoapps
    egistry.py", line 89, in populate
    11     "duplicates: %s" % app_config.label)
    12 django.core.exceptions.ImproperlyConfigured: Application labels aren't unique, duplicates: admin
    应该是admin配置冲突了,打开setttings.py文件,发现admin配置重复了
     1 INSTALLED_APPS = (
     2     'django.contrib.admin',
     3     'django.contrib.auth',
     4     'django.contrib.contenttypes',
     5     'django.contrib.sessions',
     6     'django.contrib.messages',
     7     'django.contrib.staticfiles',
     8     'django.contrib.admin',
     9     'student',
    10 )
    注释掉其中一行后(为什么会有这个问题,估计是个bug),重新启动,ok
     
     
    3、web工程添加页面
     
    此时,我们尚没有写一行代码,程序就duang跑起来了! 快添加一个Hello World的页面吧。
     
    打开student/views.py文件,输入以下内容
     
    def sayHello(request):
        s = 'Hello World!'
        current_time = datetime.datetime.now()
        html = '<html><head></head><body><h1> %s </h1><p> %s </p></body></html>' % (s, current_time)
        return HttpResponse(html)
    
    打开url.py文件,需要进行url映射的配置:
    url(r'^student/', sayHello)
    当用户输入http://**/student 时,便会调用sayHello方法,该方法通过HttpResponse()将页面内容作为响应返回。
     
    重启服务,访问http://localhost:8000/student/
     
    在views.py页面可以将页面需要的元素通过字符串的形式,调用HttpResponse()类作为响应返回到浏览器。但这样,页面逻辑和页面混合在一起,手写起来很繁琐,工作量比较大。如果我们需要展示一些动态的数据,而页面基本不改变的情况下,该怎么做呢?
    比如在用户访问 http://localhost:8000/student/ 时,我们想动态展示一些学生的数据。可以这样做:
    首先在templates目录下,新建 student.html文件,该文件作为模板,内容如下:
     1 <!DOCTYPE html>
     2 <html>
     3 <head>
     4     <title></title>
     5 </head>
     6 <body>
     7     <ul>
     8         {% for student in students %}
     9         <li>
    10             id:{{ student.id }},姓名:{{ student.name }},age: {{ student.age }}
    11         </li>
    12         {% endfor %}
    13     </ul>
    14 </body>
    15 </html>
    修改 views.py文件,添加方法showStudents()
    1 def showStudents(request):
    2     list = [{id: 1, 'name': 'Jack'}, {id: 2, 'name': 'Rose'}]
    3     return render_to_response('student.html',{'students': list})
    该方法将list作为动态数据,通过render_to_response方法绑定到模板页面student.html上。
     
    添加url映射,url(r'^showStudents/$', showStudents)
    修改settings.py模板配置:'DIRS': [BASE_DIR+r' emplates'],
     
    重启服务,访问http://localhost:8000/showStudents,出现:
     
    至此,我们已可以正常将一些“动态”数据绑定到模板上了。但是怎么样访问数据库呢?
    从数据库获取需要的数据,展示在页面上?
     
    首先需要安装数据库驱动啦,即mysql_python,
     接着配置数据库连接:
     
     1 DATABASES = {
     2     'default': {
     3         'ENGINE': 'django.db.backends.mysql',
     4         'NAME': 'student',
     5         'USER': 'root',
     6         'PASSWORD': '1234',
     7         'HOST': '127.0.0.1',
     8         'PORT': '3306',
     9         #'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    10     }
    11 }
    配置完成之后,需要检测数据库配置是否正确,使用 manage.py shell命令,进入shell交互界面:
    输入:
    1 from django.db import connection
    2 cursor = connection.cursor()
     
    如果不报错,说明配置正确。
    创建model,打开models.py,定义model如下:

    1 class Student(models.Model):
    2     id = models.BigIntegerField
    3     name = models.CharField(max_length=20, default='a')
     
    然后调用 manage.py syncdb
    正常情况下,该步骤做完之后,model 会和数据库保持一致性。但是在测试中,命令执行成功后,却发现数据库并没有建立该表。
    对于该种情况,做如下操作即可正常:
    (1)注释掉models.py文件代码,执行 manage.py makemigerations student
    【和manage.py migerate --fake】
    (2)打开注释,执行【 manage.py makemigerations student和 】manage.py migerate命令
    通过以上两步,便可正常操作了
     
    views.py中添加方法:showRealStudents
        
    1 def showRealStudents(request):
    2     list = Student.objects.all()
    3     return render_to_response('student.html', {'students': list})
    urls.py添加映射 url(r'^showRealStudents/$', showRealStudents)
     
    重启服务,打开连接:http://localhost:8000/showRealStudents
    页面输出正常。
    至此,使用Django,可以正常操作数据库,自定义模板,在页面展示数据了。
     
  • 相关阅读:
    【算法•日更•第五十五期】知识扫盲:什么是卡常数?
    【算法•日更•第五十四期】知识扫盲:什么是operator?
    【算法•日更•第五十三期】知识扫盲:什么是积性函数?
    【原】无脑操作:Webstorm集成Git/Github
    【原】无脑操作:Markdown可以这样玩
    【原】无脑操作:Eclipse + Maven + jFinal + MariaDB 环境搭建
    【原】无脑操作:Centos 7后台运行及终止jar包程序
    【原】无脑操作:TypeScript环境搭建
    【原】无脑操作:Windows下搭建Kafka运行环境
    【原】无脑操作:Chrome浏览器安装Vue.js devtool
  • 原文地址:https://www.cnblogs.com/benshan/p/4445074.html
Copyright © 2011-2022 走看看