简介:本文的首席执行官注释将介绍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管理员背景管理界面的出色特征,对于管理人员而言,它很方便地添加和删除网站的内容。
新项目系统已为我们设置了背景管理功能。请参阅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的自动化测试,持久性,中间件和国际化的知识。
这个问题得分为几个子问题
1数据库本身的时区
2个数据库数据时区
Python代码中的3个时区
首先,您可以将数据库设置以设置数据库时区,例如MySQL,直接使用SQL语句设置
其次,在存储存储时间时,尝试尽可能用时间戳将其存储。
3 python自己的时区
只有这三个点可以确保程序,数据库和数据的时区统一
Django 4.0已正式发布,版本4.0支持Python 3.8、3.9和3.10。随着Django 4.0的发布,Django 3.2的主流支持已结束。该版本主要具有以下亮点:
重要更新
Zoneinfo作为默认时区
Django 3.2允许使用非-Pytz时区。DJANGO4.0是ZoneInfo作为默认时区:废弃的Pytz,并在Django 5.0.zoneinfo中删除它是Python 3.9标准库的一部分。如果您使用的是Python 3.8,则将自动安装ZoneInfo软件包。
请注意,如果您在非UTC(世界标准时间)时区域中,并且您使用的是PYTZ normalize()和localalalize()API,则可以设置time_zone,并且需要查看代码4。Thex系列版本具有过渡使用_DEPRECCATED_PYTZ设置,可以缓慢地从PYTZ过渡到ZoneInfo。此设置将在Django 5.0中删除。
此外,ZoneInfo作者创建的PYTZ_DEPRECATION_SHIM软件包用于帮助从PYTZ迁移。该软件包提供了安全删除PYTZ的垫片,并提供了详细的迁移指南,以显示如何使用PYTZ_DEPRECATION_SHIM和use_deprecccced_pytz设置新Zoneinfo API。
功能的独特约束
UniqueConstraint()的新 *表达式位置参数可以在表达式和数据库函数上创建功能性唯一约束。例如:
使用meta.constraints选项将唯一约束添加到模型中。
添加Scrypt密码哈希设备
新的Scrypt密码哈希比PBKDF2更安全,建议使用它。但是它不是默认选项,因为它需要OpenSSL 1.1或更多版本或更多版本和更多内存。
REDIS缓存后端
新的django.core.cache.backends.redis.rediscache Cache提供了构建的 - 支持使用redis Cache。此功能需要Redis -py 3.0.0或更高版本。
基于模板的形式渲染
使用模板引擎呈现表单,例如render(),get_context()和template_name for for表单。
次要更新项目:
django.contrib.admin
django.contrib.auth
django.contrib.gis
django.contrib.postgres
django.contrib.staticfiles
缓存
新的异步API:django.core.cache.backends.base.basecache开始使缓存的后端变成短期兼容性。新的异步方法具有前缀的名称,例如AADD(),AGET(),ASET(),ASET(),ASET(),ASET(),ASET(),ASET(),ASET(),ASET(),ASET()(),aget_or_set()或adelete_many()。
将来,通常将前缀用于该方法的异步变体。
CSRF
全球化
普遍观点
Deleteview现在使用FormMixin允许您提供表单子类,例如带有确认删除的复选框。
日志
管理命令
模块
请求和响应
信号
模板
测试 ?
Django 4.0是超大版本更新。除上述更新外,它还包含一些放弃的功能以及未实现的更新功能,可以在更新公告中查看完整版本更新内容。
当使用django命令生成项目的基本结构时,配置信息将保留在settings.py文件中,以与项目目录同名目录的目录中。在实际开发中,对于一个项目,这通常是不合适的。将设置配置文件授予几个文件。将在线使用的文件放在base.py文件中,在product.py文件上的在线文件,开发测试文件放在devert.py fileessencethis函数部门中很明确,这对于我们的在线和离线调试非常方便。
1)在同名项目中,创建一个设置包(目录中包含__init__.py的文件夹)。
2)在设置软件包中创建3个新文件:public base base.py(用于配置Django默认配置文件),develop.py(用于开发环境)和product.py(用于生产环境)。
3)将原始设置的内容复制到base.py文件。
4)确认目录确定后,我们需要在base.py中修改时区和语言配置:
如果需要修改类似的公共零件,则可以在base.py(例如注册表应用程序)中修改它,这里没有示例。
5)之后,对于不同的在线和离线零件,我们只能导入base.py模块并将其修改为不同零件。例如,在线和离线对接不同的测试数据库,我们可以修改数据库连接:
6)修改Manage.py文件。使用自己的服务开始时,Django需要知道设置文件的路径。
7)生产时,请使用asgi.py(在django3.x中)或wsgi.py(django2.x版本),您可以更改生产配置文件的路径:
上述问题也有问题。如果在线和离线环境切换,我们需要更改代码,我们可以通过设置系统环境变量来动态获取它,以避免修改代码:
这样,Django通过在系统环境变量中读取Lipin_profile来加载不同的设置文件。
这可以删除原始设置.py文件!交叉
但是会有一个问题。您会发现我们无法访问以前的好网页,也找不到模板!
这是因为在先前的配置文件中,路径问题,因为我们的原始配置文件以同一名称为单位,现在我们被分为一个新软件包,因此我们需要转到第一级目录是我们需要的
根据下面的源代码,在Django设置中配置的DJANGO_CELERY_BEAT_TZ_AWARE参数可以控制Clery时间格式
查看芹菜文档
TimeZone ='亚洲/上海'#t t t t t t t t t
enable_utc = false#当参与时区时,需要此参数
timezone_aware = false#亲密意识感知
幼稚的DateTime(2014-06-15 14:38:37.873873),而时区支持活动。运行时间沃宁)
此警告的原因是Django被配置为使用TimeZone的DateTime格式,并且Date.Now不包括时区信息。
如果您不需要处理程序中的时区,则在django项目的设置中。您可以将其直接设置为“ use_tz = false”。models.deteTimeField(auto_now_add = true)和“ update_time = models.detetimefield(auto_now = true)”。
如果您仍然需要保持us_tz = true,则可以将其设置为“ default = dateTime.now()。替换(tzinfo = utc)”。
结论:以上是Django如何为Django设置相关内容答案所编写的首席CTO注释。希望它对您有所帮助!如果您解决了问题,请与更多关心此问题的朋友分享?