Field笔记

一:时区的转换

1、navie 时间 和 aware 时间

  • navie 时间:不知道自己的时间表示的是哪个时区;
  • aware 时间:知道自己的时间表示的是哪个时区。

2、pytz 库:用来处理时区的库,会经常更新时区数据,安装 django 时默认安装;(或通过 pip install pytz 安装)

3、astimezone 方法:将一个时区的时间转换为另一个时区的时间,只能被 aware 类型的时间调用,不能被 navie 类型的时间调用

 #在Linux环境下的操作;window下使用navie类型转换不会报错!
import pytz
from datetime import datetime now = datetime.now() # 这是一个 navie 类型的时间
# >>> datetime.datetime(2019, 2, 26, 20, 58, 32, 17072)
utc_timezone = pytz.timezone('UTC') # 定义UTC的时区对象
utc_now = now.astimezone(utc_timezone) # 将当前时间转换为UTC时区的时间
# >>>ValueError: astimezone() cannot be applied to a navie datetime
# 会抛出一个异常,因为navie 类型的时间不能调用astimezone # 使用replace 可将时间的某些属性进行更改,换成aware 类型后可正常转换;
now = now.replace(tzinfo=pytz.timezone('Asia/Shanghai'))
# >>> datetime.datetime(2019, 2, 26, 20, 58, 32, 17072, tzinfo=<DstTzInfo 'Asia/Shanghai' LMT+8:06:00 STD>)
utc_now = now.astimezone(utc_timezone)
# >>> datetime.datetime(2019, 2, 26, 12, 52, 32, 17072, tzinfo=<UTC>)

二:orm_intro_demo项目:

models.py:

 class Article(models.Model):
#自己定义的Field作为主键时,必须设置primary_key=True;
id = models.AutoField(primary_key=True)
#使用可以为null的BooleanField时,用NullBooleanField代替;
removed = models.NullBooleanField()
# CharField:超过254个字符时,使用TextField();
# auto_now_add:在第一次添加数据时会自动获取当前时间;
# auto_now:每次这个对象调用save()方法时都会将当前时间更新;
create_time = models.DateTimeField(auto_now=True)
# 创建时间
# 更新时间 # 1、null值:age可为空(null值),username则是一个为空的字符串而不是null值。
class Author(models.Model):
# null默认为False,没指定值时username在数据库中显示为空字符串,而不是(null);
username = models.CharField(max_length=100)
# null为True时,如果没有为age指定值则数据库中将显示(null);
age = models.IntegerField(null=True,db_column='author_age',default=0)
create_time = models.DateTimeField(auto_now=now)
# unique:在表中这个字段的值是否唯一。一般是设置手机号码 / 邮箱等。
telephone = models.CharField(max_length=11,unique=True,null=0) def __str__(self):
return "<Author id:%s,create_tiem:%s>)" % (self.id,self.create_time)
# 2、
class Meta:
#修改数据库中的表名
db_table = 'author'
#根据时间,id 的顺序来显示数据,- :为相反顺序;
ordering = ['-create_time','id']

views.py:

 # 1、null值的映射
def unique(request):
# 使用了unique 后每次添加到数据库中telephone的值都得变,它具有唯一性;
author = Author(telephone=6)
author.save()
return HttpResponse('Success') # 2、打印数据的显示顺序
def order_view(request):
authors = Author.objects.all()
for author in authors:
print(author)
return HttpResponse('success')

三:外键 (orm_ForeignKey项目)

models.py:

 # 外键
class Category(models.Model):
name = models.CharField(max_length=100) class Article(models.Model):
title = models.CharField(max_length=100)
content = models.TextField()
# 外键模型:class Foreign(to,on_delete,**options);
# to:表引用的模型;
# on_delete:后加CASCAEDE、SER_NULL等方法表外键引用的模型数据被删时的处理方法;
# category = models.ForeignKey('Category',on_delete=models.CASCADE)
# SET_DEFAULT:引用的数据被删除时可调用默认的值
category = models.ForeignKey('Category',on_delete=models.SET_DEFAULT,null=True,default=Category.objects.get(pk=1))
# app.models_name :应用名.模型名
# 引用的模型不在同个App下时使用,同App下可直接用模型名或self表示;
# author = models.Foreign('article.Category'.on_delete=CASCADE)

views.py:

from django.shortcuts import render
from .models import Article,Category
from django.http import HttpResponse def index(request):
category = Category(name='最新文章')
category.save()
article = Article(title='百年孤独',content='这本书不错...')
article.category = category
article.save()
return HttpResponse('success') # 使用CASCADE级联删除整条数据;
def author(request):
author = Category.objects.get(pk=4)
author.delete()
return HttpResponse('delete success')
上一篇:函数与方法的区别


下一篇:ruby编程语言-学习笔记5(第5章 语句和控制结构)