简介:今天,首席CTO Note将与您分享Pycharm如何启动Django项目的相关内容。如果您可以解决您现在面临的问题,请不要忘记注意此网站。让我们现在开始!
打开Pycharm的官方网站,选择下载,然后输入下载页面。
目前,将有两个版本。左侧的是购买版本,可以尝试30天;右边的一个是社区版本,免费,我们通常选择正确的社区版本。
下载后,您可以选择下一步。我不会详细介绍它。安装后运行Pycharm并创建一个新项目。此时构建的项目不是Django项目,这也要求我们自己设置它。
安装Django并使用命令安装它。我在这里使用cmder。它是替换CMD的非常有用的控制台命令窗口。输入python27的目录,使用命令PIP install django == 1.8.3,执行是可以的。
新的Django项目,我使用命令来创建项目。
django-admin startproject hellodjango
然后输入hellodjango项目的根目录,运行命令以创建Hello Module
python manage.py startapp hello
目前,Pycharm有一个Hellodjango项目。
现在,让我们构建一个简单的Web服务。
修改views.py文件
修改urls.py文件
修改两个文件后,您可以启动项目并执行命令
python manage.py迁移
python manage.py runserver
目前,该项目已经启动,它将告诉我们访问地址,根据地址,这将是可以的。
老实说,直到到目前为止,我都不欣赏django。这不是我的认知中的微妙设计。这只是功能所积累的“成熟解决方案”。但是,一切的兴起都是时代的选择。您不喜欢它,但需要它。希望有一天,Python可以拥有越来越丰富的成熟解决方案,并且不再因性能和维护而受到批评。(Fit End)
将其本质带到滴度上,Django的优势很方便。我们的源代码阅读的目的是探索其便利性的本质。阅读源代码的计划对每个地方都不好,而是解释功能的功能。
django-admin startproject helloworld可以生成django项目。命令行是EXE格式。
manage.py将参数交给了命令行。
execute_from_command_line()通过命令行参数创建管理类。然后运行他的execute()。
如果设置了重新加载,请在启动之前检查_errors。
check_errs()是一个关闭,因此在上一篇文章的末尾是(django.setup)()。
查看最后一个句子设置.installed_apps.grab从设置
请注意,此设置不是我们项目中的设置。
这是设置类的懒负载包装包装,直到__getAttr __。然后从设置类的实例中获取值,然后说将其分配给您自己的__ -dict__(我会直接找到它下次我自己,因为__getAttr __优先级)
为了促进调试,我们直接编写一个run.py。
在项目下创建一个run.py,以模拟运行服务器命令
调试抓取设置_MODULE
回到setup()中的最后一句话
开始观看apps.populate()
首先查看本段
这些应用最终被封装在appconfig中。
随后,调用了每个AppConfig的import_models()和ready()方法。
应用程序的加载部分通常是这样的
为了促进调试,我们重写了最后一句话
RES的类型是命令django.contrib.staticfiles.management.commands.runserver.com和object at 0x00000101ED5163A0
重点是第二个句子,让我们跳到run_from_argv()方法,这是几个处理参数。
用Pycharm指向手柄将进入基类,该基类无法获得正确的方向。实际上,子类已重写此方法。
这里有两种情况。如果加载重新加载,它将直接执行inner_run(),并且项目首先从其他逻辑开始。
当Django项目启动时,它实际上将启动两次。如果我们在项目入口(manage.py)中设置一个贴心,您会发现它将打印两次。
在第一个启动开始时,django_autoreload_env却没有,无法输入启动逻辑。将输入crandt_with_reloader()。
在这里,您将将django_autoreload_env放置为true,然后重新启动。
第二次,您可以输入启动逻辑。
在此创建一个Django主线程以传递innit_run()。
随后,此线程创建了一个旋转式,通过reloader.run(django_main_thread)询问监护过程。
让我们看一下django innion_run()的主线程。
当我们看到WSGI时,Django的启动逻辑已经结束。下一个作业已移交给WSGI服务器
这相当于我们之前在Fastapi中所说的话,然后将Fastapi的应用程序交给ASGI服务器(ASGI也是Django提出的,这两个基本上是同源的)
那么WSGI来自哪里?让我们回头回去
此设置是一个对象,它已从以前的操作中从settings.py配置文件中获取了自己的属性。因此,我们只需要转到settings.py配置文件即可找到。
让我们找到此get_wsgi_application()。
它将再次调用setup(),返回WSGIHANDLER类的实例很重要。
这是WSGIAPP本身。
load_middleware()是WSGIAPP构建中间件堆栈的唯一方法。
如果您之前阅读了FastAPI源代码,则应该对中间件堆栈不陌生。
应用程序入口→中间件堆栈→路由→路由节点→端点
因此,WSGIAPP已完成此操作,并将服务器传递到应用程序入口的请求中,并且可以通过中间件与该路由分配。
有时,我们需要在多个位置编辑项目,这需要在Pycharm中导入Django项目。首先要做的是使用VirtualenvWrapper构建虚拟环境,并在requestSstrents.txt文件中安装相关依赖项。
接下来要做的是:
在这里,我们需要设置Django项目的目录和设置文件的位置以及启动文件的路径
以上是项目的引入。尝试调试!交叉路口
结论:以上是首席CTO注释为所有人编辑Pycharm的全部内容。感谢您阅读本网站的内容。我希望这对您有帮助。有关Pycharm如何启动Django Project的相关内容的更多信息,请在此站点上找到它。