1、首先,如果从表单POST请求过来的时候,提交了一个日期的数据,其中是带时分秒的,通过代码获取之后是str类型的话,要转成datetime类型,可以使用python自带的datetime库,具体代码如下:
import datetime
test_time = request.POST.get('test_time')
datetime.datetime.strptime(test_time, "%Y-%m-%d %H:%M:%S")
注:如果你表单提交的日期数据是只带年月日的话,就要改下代码,把后面的格式改为"%Y-%m-%d"
2、如果后面需要把datetime的类型格式转换为YYYY-MM-DD格式的话,也就是只有年月日的话,可以使用下面代码:
from datetime import datetime
def format_date(time):
"""
返回yyyy-mm-dd格式时间
:param time:
:return:
"""
# 如果是时间格式,则转成字符串
if type(time) == datetime:
time = time.strftime('%Y-%m-%d')
# 返回时间格式
result = datetime.strptime(time, '%Y-%m-%d')
return result
3、两个datetime类型的日期,相减得到其天数,可以使用下面的方法,前提是必须是datetime类型,而且带时分秒的日期算出来的日期有可能不一样,要通过上面第二点的方法转换之后计算:
days = (end_date - start_date).days
4、datetime类型的日期加上天数,其中我测试的时候start_date是只带年月日的,加了30天得到另外一个日期:
import datetime
other_date = start_date + datetime.timedelta(days=30)
5、以上内容仅供学习参考,谢谢!