一、问题背景

在对数据进行操作的时候我们总是会遇到数据类型是date类型的数据,这种数据会让我们在使用和操作的过程中遇到一些问题,比如int类型和date类型不对等,string类型和date类型不对等的情况。而在对数据库的字段操作的时候我们更是会遇到此问题,因此在此记录一下操作方法,可以在以后的使用中直接将代码copy过来

二、问题描述

在python中使用datetime这个函数来对时间进行操作,结合数据库一起进行操作,主要内容包括:获取时间为datetime类型,string类型如何转变成datetime类型,对时间进行添加和减少等,在方法中会一一指出

模型如下:

三、方法

在datetime对象使用的过程中,如果需要获取时间就是datetime,如果不需要获取时间就是date,作为一个使用的通式

3.1 获取当前的日期和时间

代码

import datetime

print(datetime.datetime.today())  # 可以使用today
print(datetime.datetime.now()) # 也可以使用now获取

结果

3.2 获取当前的日期

代码

import datetime

print(datetime.date.today())  # 获取当前的日期

结果

3.3 对时间进行增加

3.3.1 添加天数

代码

import datetime

print(f"当前的时间:{datetime.date.today()}")
print(f"我是day:{datetime.date.today() + datetime.timedelta(days=1)}") # 增加一天的时间

结果

3.3.2 增加周数

代码

import datetime

print(f"当前的时间:{datetime.date.today()}")
print(f"我是week:{datetime.date.today() + datetime.timedelta(weeks=1)}")

结果

3.3.3 其他参数

通过查阅源码可以看到能够添加的参数,当然在date的对象下面添加的时间和分钟数是无法查看到的,需要使用datetime来进行查看

3.4 字符转成时间

使用strptime将指定的字符串转换成对应的时间对象,通过下述的结果可以看到,使用的时候进行对应来进行解析,%在SQL语句和时间中是一个标识符,作为数据的拆分结果

import datetime

str_time_0 = '2019/1/3:19/21'
str_time_1 = '2019-1-3:19/21'
str_time_2 = '2019/1/319/21'
str_time_3 = '2019/1/3:19-21'
x_0 = datetime.datetime.strptime(str_time_0, '%Y/%m/%d:%H/%M')
x_1 = datetime.datetime.strptime(str_time_1, '%Y-%m-%d:%H/%M')
x_2 = datetime.datetime.strptime(str_time_2, '%Y/%m/%d%H/%M')
x_3 = datetime.datetime.strptime(str_time_3, '%Y/%m/%d:%H-%M')

结果

3.5 时间转字符

从结果中可以看到,strftime是一个输出的格式,只需要指定其输出的格式就可以,有一点值得注意的是不能使用%,否则就会出现无法识别的错误

import datetime

y_0 = datetime.date.today()
str_time_0 = y_0.strftime("%Y-%m-%d %H:%M")
str_time_1 = y_0.strftime("%Y&%m&%d %H-%M")
str_time_2 = y_0.strftime("%Y/%m/%d-%H:%M")
print(str_time_0)
print(str_time_1)
print(str_time_2)

结果

四、实例

在数据库开发的过程中使用F查询来增加时间,可以达到快速高效的方法,如果使用原生的数据库对象就要注意timestamp的使用其使用方法和datetime一样,他的对象是time

五、总结

对于时间对象可以直接使用strftime来转成我们所需要的string的格式,对于string对象我们可以使用strptime转换成我们所需要的时间格式。举例了集中常用的时间操作方法和操作对象的手段

python操作时间的更多相关文章

  1. [py]GTM和UTC及python的时间戳

    时间戳是一串字符串 time.time() 时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总毫秒数.通俗的讲, 时间戳是一 ...

  2. python之进程与线程

    什么是操作系统       可能很多人都会说,我们平时装的windows7 windows10都是操作系统,没错,他们都是操作系统.还有没有其他的? 想想我们使用的手机,Google公司的Androi ...

  3. python高级之多线程

    python高级之多线程 本节内容 线程与进程定义及区别 python全局解释器锁 线程的定义及使用 互斥锁 线程死锁和递归锁 条件变量同步(Condition) 同步条件(Event) 信号量 队列 ...

  4. python 模块基础介绍

    从逻辑上组织代码,将一些有联系,完成特定功能相关的代码组织在一起,这些自我包含并且有组织的代码片段就是模块,将其他模块中属性附加到你的模块的操作叫做导入. 那些一个或多个.py文件组成的代码集合就称为 ...

  5. python学习笔记之常用模块(第五天)

    参考老师的博客: 金角:http://www.cnblogs.com/alex3714/articles/5161349.html 银角:http://www.cnblogs.com/wupeiqi/ ...

  6. Python之路,Day9, 进程、线程、协程篇

    本节内容 操作系统发展史介绍 进程.与线程区别 python GIL全局解释器锁 线程 语法 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Event事件 queue队列 生产者 ...

  7. python之路-Day10

    操作系统发展史介绍 进程.与线程区别 python GIL全局解释器锁 线程 语法 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Event事件 queue队列 生产者消费者模型 ...

  8. python中几个常见的“黑盒子”之 列表list

    python常见的数据类型有:字符串,布尔类型,整数,浮点数,数字,日期,列表,元祖,字典.相信前面6个大家都非常的熟悉,但是对于python的列表,元祖,字典我有时候一直在想其内部的实现是怎么样子的 ...

  9. 180分钟的python学习之旅

    最近在很多地方都可以看到Python的身影,尤其在人工智能等科学领域,其丰富的科学计算等方面类库无比强大.很多身边的哥们也提到Python非常的简洁方便,比如用Django搭建一个见得网站只需要半天时 ...

随机推荐

  1. WPF——如何为项目设置全局样式。

    在项目中,需要为所有的Button.TextBox设置一个默认的全局样式,一个个的为多个控件设置相同的样式显然是不明智的.在WPF中可以通过资源设置全局样式,主要有俩种方法: 1.第一种就是先写好按钮 ...

  2. 【win10】通过环境变量来快速打开应用程序

    step1:建一个空文件夹,并把文件夹路径复制到剪贴板. step2:依次右键点击“此电脑”.属性.高级系统设置.环境变量,定位到“系统变量”,点击新建. (说明:环境变量分为用户变量和系统变量,用户 ...

  3. 【转载】不可不知的 Android strings.xml 那些事

    相信 strings.xml 已经是大家在 Android 开发中最熟悉的文件之一了,但其实它也有很多需要注意的地方和一些小技巧,知道了这些可以让你的 Android 应用更加规范易用,大家来看看吧. ...

  4. CocoPods原理

    CocoaPods 的原理是将所有的依赖库都放到另一个名为Pods的项目中, 然而让住项目依赖Pods项目, 这样,源码管理工作任务从主项目移到了Pods项目中. 1.Pods项目最终会编译成一个名为 ...

  5. [转]Spring Cloud在国内中小型公司能用起来吗?

    原文地址:http://www.cnblogs.com/ityouknow/p/7508306.html 原文地址:https://www.zhihu.com/question/61403505 今天 ...

  6. 提升ML.NET模型的准确性

    ML.NET是一个面向.NET开发人员的开源.跨平台的机器学习框架. 使用ML.NET,您可以轻松地为诸如情绪分析.价格预测.销售分析.推荐.图像分类等场景构建自定义机器学习模型. ML.NET从0. ...

  7. 关于ML.NET v1.0 的发布说明

    今天,我们很高兴宣布发布 ML.NET 1.0.ML.NET 是一个免费的.跨平台的开源机器学习框架,旨在将机器学习(ML)的强大功能引入.NET 应用程序. ML.NET GitHub:https: ...

  8. 软件工程基础团队第二次作业(团队项目-需求分析&系统设计)成绩汇总

    一.作业题目 团队第二次作业:需求分析&系统设计 二.具体要求 1.作业任务 任务一:组长组织项目组开展需求调研工作(可采取需求调查.问卷.分析已有软件.网上资料等方法).概要设计.详细设计. ...

  9. 6. Go语言—字符串操作

    一.字符串支持的转义字符 \r 回车符(返回行首) \n 换行符(直接跳到下一行的同列位置) \t 制表符 \' 单引号 \" 双引号 \\ 反斜杠 \uXXXX Unicode字符码值转义 ...

  10. Pwnable-leg

    Download : http://pwnable.kr/bin/leg.c Download :http://pwnable.kr/bin/leg.asm 友链 https://blog.csdn. ...