Django中datetime类型的相关操作(记录一下)

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、以上内容仅供学习参考,谢谢!

发布了276 篇原创文章 · 获赞 200 · 访问量 72万+

猜你喜欢

转载自blog.csdn.net/u012561176/article/details/89703059