Python基础编程20例之五:判断某一天是一年中的第几天

liftword7个月前 (12-16)技术文章70

20221230星期五:


输入指定格式的日期,然后判断这一天是一年中的第几天:

# 方式一:datetime函数:
from datetime import *
da = input("请输入年月日,输入格式为xxxx-xx-xx:")
da1 = datetime.strptime(da[:4] + '-1-1','%Y-%m-%d')
da2 = datetime.strptime(da,'%Y-%m-%d')
print(type(da1),da1) # <class 'datetime.datetime'> 2022-01-01 00:00:00
print(type(da2),da2) # <class 'datetime.datetime'> 2022-12-22 00:00:00
print("今天是一年中的第 {} 天".format((da2-da1).days+1),type(da2))



# 方式二:datetime.date函数:
from datetime import *
def findDays():
    year = int(input("请输入年份:"))
    month = int(input("请输入月份:"))
    day = int(input("请输入日期:"))

    da1 = date(year,month,day)
    da2 = date(year,month=1,day=1)

    count = (da1-da2).days+1
    print(count)
findDays()



# 方式三:比较繁琐的办法:
'''
    以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊
    情况,闰年且输入月份大于3时需考虑多加一天
'''

da = input("请输入日期,格式为XXXX-XX-XX:")
date = da.split('-')
year = int(date[0])
month = int(date[1])
day = int(date[2])

list_month = [31,28,31,30,31,30,31,31,30,31,30,31]
print('计算前:平年闰年:',list_month[1])
count_day = 0
if((year % 4 == 0 and year % 100 != 0) or (year % 400 == 0)):
    list_month[1] = 29
print('平年闰年:',list_month[1])
for i in range(12):
    if month > i + 1:
        count_day += list_month[i]
    else:
        count_day += day
        break
print("这一天是 {} 年的第 {} 天".format(year,count_day))

相关文章

Python中的日期和时间处理 python处理日期数据

在Python编程语言中,日期和时间的处理是一项常见且重要的任务。Python提供了一个强大的内置模块datetime,它允许我们以多种方式操作日期和时间。本文将通过一系列示例,深入探讨如何在Pyth...

在pandas中保存Excel文件的日期字段(只保留年月日)

在使用pandas保存日期数据时,我们经常会只希望保存成日期类型,即类似2021-01-16的格式。但是由于pandas的Timestamp类可以处理时分秒,如果不进行处理,默认情况下,在输出成Exc...

Python办公自动化之Excel做表自动化

Excel与Python都是数据分析中常用的工具,本文将使用动态图(Excel)+代码(Python)的方式来演示这两种工具是如何实现数据的读取、生成、计算、修改、统计、抽样、查找、可视化、存储等数据...

Notepad++快速插入日期时间 notepad批量添加

在Notepad++中快速插入日期时间,我们需要先启用插件“Python Script”,如下图所示,进入“插件管理”。搜索插件“Python Script”,选中这个插件,安装,安装成功后可以不重启...