python操作时间
一、问题背景
在对数据进行操作的时候我们总是会遇到数据类型是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操作时间的更多相关文章
- [py]GTM和UTC及python的时间戳
时间戳是一串字符串 time.time() 时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总毫秒数.通俗的讲, 时间戳是一 ...
- python之进程与线程
什么是操作系统 可能很多人都会说,我们平时装的windows7 windows10都是操作系统,没错,他们都是操作系统.还有没有其他的? 想想我们使用的手机,Google公司的Androi ...
- python高级之多线程
python高级之多线程 本节内容 线程与进程定义及区别 python全局解释器锁 线程的定义及使用 互斥锁 线程死锁和递归锁 条件变量同步(Condition) 同步条件(Event) 信号量 队列 ...
- python 模块基础介绍
从逻辑上组织代码,将一些有联系,完成特定功能相关的代码组织在一起,这些自我包含并且有组织的代码片段就是模块,将其他模块中属性附加到你的模块的操作叫做导入. 那些一个或多个.py文件组成的代码集合就称为 ...
- python学习笔记之常用模块(第五天)
参考老师的博客: 金角:http://www.cnblogs.com/alex3714/articles/5161349.html 银角:http://www.cnblogs.com/wupeiqi/ ...
- Python之路,Day9, 进程、线程、协程篇
本节内容 操作系统发展史介绍 进程.与线程区别 python GIL全局解释器锁 线程 语法 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Event事件 queue队列 生产者 ...
- python之路-Day10
操作系统发展史介绍 进程.与线程区别 python GIL全局解释器锁 线程 语法 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Event事件 queue队列 生产者消费者模型 ...
- python中几个常见的“黑盒子”之 列表list
python常见的数据类型有:字符串,布尔类型,整数,浮点数,数字,日期,列表,元祖,字典.相信前面6个大家都非常的熟悉,但是对于python的列表,元祖,字典我有时候一直在想其内部的实现是怎么样子的 ...
- 180分钟的python学习之旅
最近在很多地方都可以看到Python的身影,尤其在人工智能等科学领域,其丰富的科学计算等方面类库无比强大.很多身边的哥们也提到Python非常的简洁方便,比如用Django搭建一个见得网站只需要半天时 ...
随机推荐
- PlayJava Day002
今日所学: /* 2019.08.19开始学习,此为补档. */ 流程控制 条件: 一重用if 二重用if ... else 三重用if ... else if ... else 多重用switch ...
- python凯撒加密
在密码学中,恺撒密码是一种最简单且最广为人知的加密技术.它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文.例,当偏移量是3的时候,所有的字母A将 ...
- 交互式shell脚本web console
官网:http://web-console.org/ 这个脚本可以实现web下交互,也就是有了这玩意后可以不用反弹shell了. <?php // Web Console v0.9.7 (201 ...
- SQLi-LABS Page-3 (Stacked injections) Less-38-Less-45
Less-38 堆叠注入原理简介堆叠注入简介 Stacked injections: 堆叠注入.从名词的含义就可以看到应该是一堆 sql 语句(多条)一起执行.而在真实的运用中也是这样的, 我们知道在 ...
- Python 字符串用法总结
一.将某个对象转换为字符串,有str()和repr()两种方法 区别:repr() 转化为供解释器读取的形式str() 转化为适于人阅读的形式 a = 123456 print('repr输出:', ...
- React教程:4 个 useState Hook 示例
摘要: React示例教程. 原文:快速了解 React Hooks 原理 译者:前端小智 到 React 16.8 目前为止,如果编写函数组件,然后遇到需要添加状态的情况,咱们就必须将组件转换为类组 ...
- 记录Flex布局的属性
容器属性 flex-dirextion(主轴的方向):>>row(水平) | row-reverse(水平取反) | column(垂直) | column-reverse(垂直取反) f ...
- 4-8 pie与布局
In [1]: %matplotlib inline import matplotlib.pyplot as plt 1.pie简单参数:plt.pie(x, explode=None, labe ...
- SpringCloud学习笔记(四、SpringCloud Netflix Ribbon)
目录: Ribbon简介 Ribbon的应用 RestTemplate简介 Ribbon负载均衡源码分析 Ribbon简介: 1.负载均衡是什么 负载均衡,根据其字面意思来说就是让集群服务具有共同完成 ...
- LeetCode 63. Unique Paths II不同路径 II (C++/Java)
题目: A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). ...