本来想上午轻轻松松搞定,没想到还是出了其他的问题,好在最后都解决了

在middleware.py当中
  1. # -*- coding:utf-8 -*-
  2. __author__ = 'feimao'
  3. import re 正则表达式处理方式
  4. from django.shortcuts import render
  5. class Version(object):
  6. def process_request(self,request):
  7. agent = request.META['HTTP_USER_AGENT']获取浏览器版本信息,通过request获取
  8. result = re.findall('MSIE [5678]', agent)匹配符合条件的字符串
  9. if len(result)>0:
  10. return render(request,'warning.html') 用render方法发挥渲染过的页面,不用进行跳转,跳转比较麻烦,但是需要了解一下

定义了中间件,在settings.py里面是这么写的
'todolist.middleware.Version',
然后就可以顺利使用了 

然后是定义过滤器
在templatetags包里定义了
  1. # -*- coding: utf-8 -*-
  2. from django import template
  3. register = template.Library()
  4. from datetime import datetime
  5. __author__ = 'feimao'
  6. @register.filter
  7. def times(value):
  8. result = '刚刚'
  9. now = datetime.utcnow()
  10. value = value.replace(tzinfo=None)
  11. days = (now-value).days
  12. if days != 0:
  13. result = str(days)+'天前'
  14. else:
  15. seconds =(now-value).seconds
  16. if seconds/3600 != 0 :
  17. result = str(seconds/3600) + '小时前'
  18. else:
  19. result = str(seconds/60) + '分钟前'
  20. return result
这里就比较恶心了,因为在数据库当中保存的时间格式是UTC的格式,所以我就直接取当前时间的UTC格式了
now = datetime.utcnow()
但是我发现还是不能够直接相减否则会报can't subtract offset-naive and offset-aware datetimes这样的错误
问题就出在利用datetime.datetime.now()得到的当前时间是offset-naive的,而另外一个却是offset-aware的,因此我们需要将这里的dt转成与now一样的形式,可以这么做:
1
2
3
4
5
>>> dt = dt.replace(tzinfo=None)
>>> dt
datetime.datetime(201441815377)
>>> now - dt
datetime.timedelta(034108443000)

这样写就可以了



















Django进阶项目的更多相关文章

  1. python 自动化之路 day 20 Django进阶/BBS项目【一】

    一.django进阶 1.django orm 增删改查 1.1.创建表: 1 2 3 >>> from blog.models import Blog >>> b ...

  2. 老王Python培训视频教程(价值500元)【基础进阶项目篇 – 完整版】

    老王Python培训视频教程(价值500元)[基础进阶项目篇 – 完整版] 教学大纲python基础篇1-25课时1.虚拟机安装ubuntu开发环境,第一个程序:hello python! (配置开发 ...

  3. Django进阶篇【1】

    注:本篇是Django进阶篇章,适合人群:有Django基础,关于Django基础篇,将在下一章节中补充! 首先我们一起了解下Django整个请求生命周期: Django 请求流程,生命周期: 路由部 ...

  4. Django进阶知识

    drf学习之Django进阶点 一.Django migrations原理 1.makemigrattions: 相当于在每个app下的migrations文件夹下生成一个py脚本文件用于创建表或则修 ...

  5. python web框架 Django进阶

    django 进阶 基础中,一些操作都是手动创建连接的非主流操作,这样显得太low,当然也是为了熟悉这个框架! 实际中,django自带连接数据库和创建app的机制,同时还有更完善的路由系统机制.既然 ...

  6. django创建项目

    django创建项目 安装django pip install django==1.9 Note: C:\Python34\Scripts\pip.exe 创建项目 django-admin star ...

  7. Django练习项目之搭建博客

    背景:自从今年回家过年后,来到公司给我转了试用,我的学习效率感觉不如从前,而且刚步入社会我总是想要怎么想明白想清楚一些事,这通常会花掉,消耗我大量的精力,因为我想把我的生活管理规划好了,而在it技术学 ...

  8. Python之路,Day16 - Django 进阶

    Python之路,Day16 - Django 进阶   本节内容 自定义template tags 中间件 CRSF 权限管理 分页 Django分页 https://docs.djangoproj ...

  9. django进阶补充

    前言: 这篇博客对上篇博客django进阶作下补充. 一.效果图 前端界面较简单(丑),有两个功能: 从数据库中取出书名 eg: 新书A 在form表单输入书名,选择出版社,选择作者(多选),输入完毕 ...

随机推荐

  1. 92. Reverse Linked List II【Medium】

    92. Reverse Linked List II[Medium] Reverse a linked list from position m to n. Do it in-place and in ...

  2. centos配置IP地址

    1. vi /etc/sysconfig/network-scripts/ifcfg-eth0 2. DEVICE=eth1HWADDR=00:0C:29:D2:9A:F5TYPE=EthernetU ...

  3. Yarn源码分析之MRAppMaster上MapReduce作业处理总流程(一)

    我们知道,如果想要在Yarn上运行MapReduce作业,仅需实现一个ApplicationMaster组件即可,而MRAppMaster正是MapReduce在Yarn上ApplicationMas ...

  4. hdu 4272 LianLianKan 状态压缩

      LianLianKan Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Tot ...

  5. OpenCV中Kinect的使用(3)

    接OpenCV中Kinect的使用(2),下面内容主要讲述使用OpenNI 控制Kinect 的马达,实现摄像头的上下摆动. 下面是透过OpenNI比较低阶的USB控制介面(XnUSB.h),来做到马 ...

  6. Struts2 结果和结果类型

    正如前面提到的,<results>标签在Struts2的MVC框架的视图中所扮演的角色.动作是负责执行业务逻辑.执行业务逻辑后,接下来的步骤是使用<results>标签显示的视 ...

  7. android中TabHost和RadioGroup

    android底部菜单应用 博客分类: android--UI示例 TabHostMenuRadioGroupButton  在android中实现菜单功能有多种方法. Options Menu:用户 ...

  8. C++ 虚析构(virtual destructor)原理

    注意:本文仅为个人理解,可能有误! 先看一段代码: #include <iostream> using namespace std; class CBase{ public: CBase( ...

  9. Laravel创建Route

    <?php /* |-------------------------------------------------------------------------- | Routes Fil ...

  10. dva解读1

    1.首先定义一个app对象实现dva const app = dva({ history: createHistory(), }); // 2. Plugins app.use(createLoadi ...