皮皮网

【服务器状态监控源码】【程序源码壁纸】【docker源码脚本】LHJ源码

来源:usb手柄源码 时间:2024-11-22 20:17:55

1.django如何将print内容打印(2023年最新整理)

LHJ源码

django如何将print内容打印(2023年最新整理)

       导读:本篇文章首席CTO笔记来给大家介绍有关django如何将print内容打印的相关内容,希望对大家有所帮助,一起来看看吧。

可不可以将python脚本运行的结果通过django在网页上显示出来

       将stdout重定向到网页,可以将所有输出都显示到网页上。其实就是服务器状态监控源码写一个类,例如写一个classhtml_out(这个类要有write和read函数,以模仿一个file),将sys.stdout输出重定向到html_out这个类上。html_out里面加一些函数处理一下输出,将输出转换成html的文本格式,然后返回到浏览器的请求上。类似这样的pytestlhj(dot)herokuapp(dot)com

       Django源码阅读(一)项目的生成与启动

       诚实的说,直到目前为止,我并不欣赏django。程序源码壁纸在我的认知它并不是多么精巧的设计。只是由功能堆积起来的"成熟方案"。但每一样东西的崛起都是时代的选择。无论你多么不喜欢,但它被需要。希望有一天,python能有更多更丰富的成熟方案,且不再被诟病性能和可维护性。(屁话结束)

       取其精华去其糟粕,django的优点是方便,我们这次源码阅读的目的是探究其方便的本质。计划上本次源码阅读不会精细到每一处,而是大体以功能为单位进行解读。

       django-adminstartprojectHelloWorld即可生成django项目,docker源码脚本命令行是exe格式的。

       manage.py把参数交给命令行解析。

       execute_from_command_line()通过命令行参数,创建一个管理类。然后运行他的execute()。

       如果设置了reload,将会在启动前先check_errors。

       check_errors()是个闭包,所以上文结尾是(django.setup)()。

       直接看最后一句settings.INSTALLED_APPS。从settings中抓取app

       注意,这个settings还不是我们项目中的settings.py。而是一个对象,位于django\conf\__init__.py

       这是源码打包步骤个Settings类的懒加载封装类,直到__getattr__取值时才开始初始化。然后从Settings类的实例中取值。且会讲该值赋值到自己的__dict__上(下次会直接在自己身上找到,因为__getattr__优先级较低)

       为了方便debug,我们直接写个run.py。不用命令行的方式。

       项目下建个run.py,模拟runserver命令

       debug抓一下setting_module

       回到setup()中的最后一句apps.populate(settings.INSTALLED_APPS)

       开始看apps.populate()

       首先看这段

       这些App最后都会封装成为AppConfig。且会装载到self.app_configs字典中

       随后,分别调用每个appConfig的import_models()和ready()方法。

       App的装载部分大体如此

       为了方便debug我们改写下最后一句

       res的类型是Commanddjango.contrib.staticfiles.management.commands.runserver.Commandobjectat0xEDA0

       重点是第二句,让我们跳到run_from_argv()方法,这里对参数进行了若干处理。

       用pycharm点这里的源码安全分析handle会进入基类的方法,无法得到正确的走向。实际上子类Commond重写了这个方法。

       这里分为两种情况,如果是reload重载时,会直接执行inner_run(),而项目启动需要先执行其他逻辑。

       django项目启动时,实际上会启动两次,如果我们在项目入口(manage.py)中设置个print,会发现它会打印两次。

       第一次启动时,DJANGO_AUTORELOAD_ENV为None,无法进入启动逻辑。会进入restart_with_reloader()。

       在这里会将DJANGO_AUTORELOAD_ENV置为True,随后重启。

       第二次时,可以进入启动逻辑了。

       这里创建了一个django主线程,将inner_run()传入。

       随后本线程通过reloader.run(django_main_thread),创建一个轮询守护进程。

       我们接下来看django的主线程inner_run()。

       当我们看到wsgi时,django负责的启动逻辑,就此结束了。接下来的工作交由wsgi服务器了

       这相当于我们之前在fastapi中说到的,将fastapi的app交由asgi服务器。(asgi也是django提出来的,两者本质同源)

       那么这个wsgi是从哪来的?让我们来稍微回溯下

       这个settings是一个对象,在之前的操作中已经从settings.py配置文件中获得了自身的属性。所以我们只需要去settings.py配置文件中寻找。

       我们来寻找这个get_wsgi_application()。

       它会再次调用setup(),重要的是,返回一个WSGIHandler类的实例。

       这就是wsgiapp本身。

       load_middleware()为构建中间件堆栈,这也是wsgiapp获取setting信息的唯一途径。导入settings.py,生成中间件堆栈。

       如果看过我之前那篇fastapi源码的,应该对中间件堆栈不陌生。

       app入口→中间件堆栈→路由→路由节点→endpoint

       所以,wsgiapp就此构建完毕,服务器传入请求至app入口,即可经过中间件到达路由进行分发。

djangotest怎么打印sql

       Django提供了sql,sql_all命令来生成MODEL的SQL语句,当定义好DjangoModel后,可以在初始化调用Syncdb方法来自动在数据库里面生成相应的表。

       Model定义如下:

       classTestModel(models.Model):

       Name=models.CharField(max_length=,blank=True)

       fromdjango.core.management.colorimportno_style

       #Style是用来输出语句时着色的

       fromdjango.dbimportconnection

       fromdjango.db.backendsimportcreation

       #这里面有个类BaseDatabaseCreation,就是用来生成SQL语句的。

       T=TestModel()

       c=creation.BaseDatabaseCreation(connection)

       c.sql_create_model(T,no_style())[0]

       ['CREATETABLE"abc"(\n"id"integerNOTNULLPRIMARYKEY,\n"Theme"varchar()NOTNULL\n)\n;']

       这样就可以通过Django取得这个模型的SQL定义语句了,并且针对不同的数据库处理Django已经帮做好了。

pythondjango怎么把数据查询结果保存到一个list里面

       1、新建一个JUPYTERNOTEBOOK文档。

       2、定义一个LIST列表并且打印看看结果。list=[3,9,-7]print(list)。

       3、为列表增加一个数字。list.append()print(list)。

       4、字符串也是可以增加进去的。list.append("string")print(list)。

       5、列表里面更是可以含有其它列表。list.append([-3,-4])print(list)。

       6、如果要删除最后一个列表的值,可以这样处理。list.pop()print(list)。

       结语:以上就是首席CTO笔记为大家介绍的关于django如何将print内容打印的全部内容了,希望对大家有所帮助,如果你还想了解更多这方面的信息,记得收藏关注本站。