当前位置: 首页 > 网络应用技术

如何在Django项目中添加日志(Django以构建个人博客)

时间:2023-03-07 19:05:28 网络应用技术

  简介:本文的首席执行官注释将介绍有关如何在Django项目中添加日志的相关内容。我希望这对每个人都会有所帮助。让我们来看看。

  django中使用的timedRotatingFileHandler记录的日志处理日志处理。预期的效果是每日日志仅存储在文件中。

  但是在实际操作中,遇到了两个棘手的问题。一个是直接与runserver一起运行,runserver随附django,并在滚动时报告错误,提示其他程序占据日志文件。另一个是部署IIS时,它是发现它不会自动Rolover,并且所有日志仍然具有单独的文件。

  第一个问题可以由-noreload参数直接使用。原因也已在[Django]日志函数之前编写。

  第二个问题非常奇怪。可能的原因是设置参数“ where”:“ d”无法实现预期目的。此参数是指根据间隔1天记录日志(默认为1天)。无法触发。

  解决方案是修改参数“ where”:“ Midnight”,以便每天发布新的日志消息,它将触发日志文件的翻转并实现预期效果。

  本文演示了如何使用1.7的Django版本创建一个简单的Django网站。

  1.创建项目

  运行以下命令来创建Django项目。项目名称是MySite:

  $ django- addmin.py startproject mysite

  创建的项目目录如下:

  我的网站

  e- manage.py

  t - 锰矿

  t- __init__.py

  在──设置.py

  s-或urls.py

  。─— wsgi.py

  1个目录,5个文件

  阐明:

  __init__.py:让Python将目录作为开发包所需的文件(即一组模块)。这是一个空文件,通常您不需要修改它。

  Manage.py:命令行工具允许您通过多种方式与Django项目进行交互。类型python manage.py帮助查看它可以做什么。您不需要编辑此文件;在此目录中为方便起见是纯粹的。

  settings.py:Django项目的设置或配置。

  urls.py:项目的URL路由设置。目前,它是空的。

  wsgi.py:wsgi Web应用程序服务器配置文件。有关更多详细信息,请检查如何使用WSGI部署

  接下来,您可以修改settings.py文件,例如:修改Lagansy_code,设置时区time_zone

  SIT_ID = 1

  lanking_code ='zh_cn'

  time_zone ='亚洲/上海'

  use_tz = true

  [时区]()功能在上方打开。您需要安装pytz:

  $ sudo pip安装pytz

  2.操作项目

  在运行项目之前,我们需要创建一个数据库和表结构。我在这里使用的默认数据库:

  $ python manage.py迁移

  执行操作:

  应用所有迁移:管理员,contenttypes,auth,sessions

  运行迁移:

  应用ContentTypes.0001_Initial ...确定

  应用auth.0001_initial ...确定

  应用管理员0001_Initial ...确定

  应用sessions.0001_initial ...好的

  然后开始服务:

  $ python manage.py runserver

  您将看到以下输出:

  执行系统检查...

  系统检查没有问题(0沉默)。

  2015-02 1月28日:08:33

  Django版本1.7.1,用户设置“ mysite.settings”

  启动开发服务器

  使用Control-C退出服务器。

  这将在端口8000启动本地服务器,只能从您的计算机连接和访问。现在服务器正在运行,现在可以访问Web浏览器。它开始工作。

  您还可以指定启动端口:

  $ python manage.py runserver 8080

  并指定的IP:

  $ python manage.py runserver 0.0.0.0:8000

  3.创建一个应用程序

  一个项目是更早创建并成功运营的。现在,要创建一个应用程序,应用程序等同于项目的子模块。

  在项目目录中创建一个应用程序:

  $ python manage.py startapp民意调查

  如果操作成功,您将在MySite文件夹下看到一个称为民意调查的文件夹。目录结构如下:

  民意调查

  t- __init__.py

  .- admin.py

  在移民

  │_ _- __init__.py

  s- models.py

  。—— tests.py

  s - 视图。

  1个目录,6个文件

  4.创建模型

  每个Django模型都从django.db.models.model继承

  模型中每个属性的每个属性代表数据库字段

  通过Django模型API

  在民意调查文件夹下打开Models.py文件。创建两个模型:

  导入日期

  来自django.db导入模型

  来自django.utils重要时区

  班级问题(Models.Model):

  Question_Text = model.Charfield(max_length = 200)

  pub_date = model.dateTimeField('Date已发布')

  def was_publish_recression(seld):

  返回self.pub_date = timezone.now()-dateTime.timedelta(天= 1)

  班级选择(Models.Model):

  问题=模型。Foreignkey(问题)

  choce_text = models.charfield(max_length = 200)

  投票= model.integerfield(默认= 0)

  然后修改inporthed_apps以在mySite/settings.py中添加民意调查:

  instasted_apps =((

  'django.contrib.admin',

  'django.contrib.auth',

  'django.contrib.contenttypes',

  'django.contrib.sessions',

  'django.contrib.messages',

  'django.contrib.staticfiles',

  “民意调查”,

  治愈

  添加新应用程序后,我们需要运行以下命令来告诉Django您的模型以进行更改。迁移数据库需要迁移:

  $ python manage.py makemigrations民意调查

  您将看到以下输出日志:

  “民意调查”的迁移:

  0001_Initial.py:

  - 创建模型选择

  - 创建模型问题

  -DD现场问题选择

  您可以从民意调查/迁移/0001_Initial.py查看迁移语句。

  运行以下语句,您可以查看迁移SQL语句:

  $ python manage.py sqlmigrate民意调查0001

  输出结果:

  开始;

  创建表“ polls_choice”(“ id”整数而不是null主键自动启动,“ choice_text” varchar(200)而不是null,“投票” integer而不是null);

  创建表“ polls_question”(“ id”整数而不是null主键自动启动,“ Question_Text” Varchar(200)不是null,“ pub_date” dateTime null)

  

  插入“ polls_choice__new”(“ phoce_text”,“票”,“ id”)选择“ polls_choice”中的“ choice_text”,“票数”,“投票”,“ id”

  丢弃表“ polls_choice”;

  Alter Table“ Polls_Choice__new”重命名为“ Polls_Choice”;

  在“ Polls_Choice”(“ Question_ID”)上创建索引Polls_choice_7aa0f6ee;

  犯罪;

  您可以运行以下命令以检查数据库是否存在问题:

  $ python manage.py检查

  再次运行以下命令以创建新添加的模型:

  $ python manage.py迁移

  执行操作:

  应用所有迁移:管理员,内容类型,民意调查,auth,会议

  运行迁移:

  应用民意调查。0001_Initial...好的

  总而言之,在修改模型时,您需要执行以下步骤:

  修改型号.py文件

  运行python manage.py makemigrations创建迁移语句

  运行python manage.py迁移并迁移模型更改为数据库

  您可以阅读django-admin.py文档以查看更多管理。

  创建模型后,我们可以通过Django提供的API进行测试。run以下命令输入Python Shell的交互模式:

  $ python manage.py shell

  这是一些测试:

  从polls.models导入问题,选择#导入我们刚刚编写的模型类。

  #系统中还没有问题。

  Question.Objects.all()

  []

  #创建一个新问题。

  #在默认设置文件中启用了对时区的支持,因此

  #Django用tzinfo for pub_date来实现DateTime。使用timezone.now()

  #而不是面团。dateTime.now(),它将做正确的事情。

  来自django.utils重要时区

  Q = Question(Question_text =“什么新功能?”,pub_date = timezone.now())

  #将对象保存到数据库中。您必须明确调用Save()。

  问:Save

  #现在它有一个ID。请注意,这可能会说“ 1”的“ 1”,具体取决于

  #您使用哪个数据库。那不是大事;这只是意味着你

  #数据库后端喜欢返回整数作为Python长整数

  #对象。

  Q.ID

  1

  #通过Python属性访问模型字段值。

  Q.question_text

  “什么是新的?”

  q.pub_date

  dateTime.dateTime(2012,2,26,13,0,0,0,775217,tzinfo = utc)

  #Change值通过更改属性,然后调用Save()。

  q.question_text =“怎么了?”

  问:Save

  #Objects.all()显示数据库中的所有问题。

  Question.Objects.all()

  [问题:问题对象]

  打印所有问题时,输出的结果是[问题:问题对象]。我们可以修改模型类以使其更容易理解。修改模型类:

  来自django.db导入模型

  班级问题(Models.Model):

  #...

  def __str __(self):#__unicode__ python 2

  返回self.question_text

  班级选择(Models.Model):

  #...

  def __str __(self):#__unicode__ python 2

  返回self.choice_text

  继续测试:

  从民意调查。模型导入问题,选择

  #确保我们的__str __()加法工作。

  Question.Objects.all()

  [问题:怎么了?]

  #Django提供了一个富含数据库的查找API,该API完全由

  #关键字参数。

  Question.Objects.Filter(ID = 1)

  [问题:怎么了?]

  Question.Objects.Filter(Question_text_Startswith ='What')

  [问题:怎么了?]

  #获取今年提出的问题。

  来自django.utils重要时区

  curren_year = timezone.now()。年

  Question.Objects.get(pub_date__year = current_year)

  问题:怎么了?

  #请求ID,这将引起例外。

  Question.Objects.get(ID = 2)

  Trackback(最近的最新电话):

  Em

  dotNotexist:不存在问题匹配查询。

  #主键查找是最合并的情况,因此Django提供了一个

  #主要钥匙精确查找的快捷方式。

  #跟随者与Question.objects.get(ID = 1)相同。

  Question.Objects.get(PK = 1)

  问题:怎么了?

  #确保我们的自定义方法有效。

  Q = Question.Objects.get(PK = 1)

  #给出一些选择。创建呼叫构造一个新的

  #选择对象,执行插入语句,将选择添加到集合

  可用选择的#并返回新选择对象。Django创建

  #一套持有外国关系的“另一面”

  #(例如,一个问题的选择)可以通过API访问。

  Q = Question.Objects.get(PK = 1)

  #从相关对象集中显示任何选择 - 到目前为止无。

  q.choice_set.all()

  []

  #创建三个选择。

  Q.CHOICE_SET.CREATE(choce_text ='不多',票数= 0)

  选择:不多

  Q.CHOICE_SET.CREATE(choce_text ='the Sky',投票= 0)

  选择:天空

  c = q.choice_set.create(choce_text ='再次黑客入侵',票数= 0)

  #选择对象可以访问其相关问题对象。

  C.问题

  问题:怎么了?

  #和VICE,反之亦然:问题对象可以访问选择对象。

  q.choice_set.all()

  [选择:不是泥土,选择:天空,选择:再次入侵]

  q.choice_set.count()

  3

  #API自动食品遵循您需要的相关船。

  #使用面团下划线选择相关职位。

  #这是您想要的深层层次的工作。没有限制。

  #找到今年Pub_date的任何问题的所有选择

  #(重用我们上面创建的“ Current_Year”变量)。

  choce.objects.filter(问题__pub_date__year = current_year)

  [选择:不是泥土,选择:天空,选择:再次入侵]

  #让我们删除其中一个选择。为此使用delete()。

  c = q.choice_set.filter(choce_text__startswith ='Just Hacking')

  c.delete()

  以上测试涉及与Django Orm相关的知识。有关详细信息,请参阅Django中的ORM。

  5.管理管理员

  Django具有构建-Django Admin背景管理接口的出色特征,对于管理人员而言,它很方便地添加和删除网站的内容。

  新项目系统已为我们设置了背景管理功能。请参阅mySite/settings.py:

  instasted_apps =((

  'django.contrib.admin',#

  'django.contrib.auth',

  'django.contrib.contenttypes',

  'django.contrib.sessions',

  'django.contrib.messages',

  'django.contrib.staticfiles',

  '我的网站',

  治愈

  同时,添加了进入背景管理的URL。您可以在MySite/urls.py中查看它:

  url(r'^admin/',infulude(admin.site.urls)),#可以使用SET URL进入网站的背景

  接下来,我们需要创建管理用户来登录到管理背景管理接口:

  $ python manage.py createSuperuse

  用户名(留空白以使用“六月”):管理员

  电子邮件地址:

  密码:

  密码(再次):

  超级用户成功创建了。

  总结

  最后,查看项目目录结构:

  我的网站

  Q - db.sqlite3

  e- manage.py

  t - 锰矿

  │_ _- __init__.py

  │e ─—设置.py

  │u - urURLS.PY

  │s-wsgi.py

  S - 民意调查

  │_ _- __init__.py

  │d - 管理

  │i - 移民

  ││├├─-0001_Initial.py

  ││├─..__Init__.py

  │o - models.py

  │e - ─-模板

  民意调查

  ││├├─detail.html

  ││├ - index.html

  thml

  │e - tests.py

  │u - urURLS.PY

  │i - ─视图。

  L ─—模板

  在─管理员

  _ - base_site.htm

  通过上面的介绍,我对Django的安装,操作以及如何创建视图以及如何创建视图和模型有了清晰的了解。接下来,您可以彻底了解Django的自动化测试,持久性,中间件和国际化的知识。

  设计和实施基于Python的个人博客系统,您需要完成以下功能

  完成个人博客系统的设计和开发

  用户可以通过个人博客系统发布最新日志

  使用您学会的理论和实践来分析遇到的问题,以提高您的做法,思考和解决问题

  主要模块如下

  文章管理模块:主要功能是登录到管理员系统管理员,删除不良文章和其他功能后浏览文章

  标签管理模块:主要功能是在登录到管理员系统管理员后浏览专辑,删除相册和其他功能

  文章,标签浏览模块:主要功能是在游客进入系统之后。您可以浏览文章列表,您可以根据标签查看文章

  评论系统模块,游客可以发表其他人的评论

  安装和使用

  该项目是由Django框架开发的。Django是快速网络开发(几乎没有人)的绝佳解决方案。获得源代码后

  创建一个新的MySQL数据库,以将数据库SQL文件导入到

  在源代码软件包中修改csworkblog/settings.py文件,更改数据库变量中的内容。这是您本地数据库URL和用户名密码。其中,名称是您的数据库名称。

  输入源代码软件包,打开CMD,运行命令python manager.py runserver启动服务,端口为8000

  对于背景管理接口,管理员的用户名密码为管理员123456,可以通过文章管理标签管理评论管理管理

  接口仍然更好,项目屏幕截图源代码下载地址CS- work.com/p/21031

  在Python中,您可以将Python的安装环境添加到系统变量(我记得自动添加,您可以直接在DOS下运行Python)

  至于django,您可以直接运行django-admin startproject mysite2(django-admin无.py),而没有python django-admin.py startproject mySite 2(如果需要多变的)

  如何实现背景Django系统操作日志

  首先构建管理日志表。

  然后构建负责日志表操作的类

  我的日志表就是这样

  日志ID

  管理员ID

  管理员名称

  操作类型

  操作名称(执行什么)

  时间

  IP地址

  评论

  ----------------------------------------------------------------------------------------------------------------------------------------

  当然,根据您的需要,您可以构建一个更复杂的日志表。

  我有一个日志,其中有一个静态方法。

  当您需要记录日志时,我会打电话给

  eventlog.logevent(...)

  ------------------------------------------------------------------------------------------------------------------------------------------------------------

  至于节目,这很简单。您如何检查,可以使用最简单的绑定到datagrid

  结论:以上是Django项目如何为首席执行官注释添加日志的所有内容。感谢您阅读本网站的内容。我希望它对您有所帮助。