【Python练习题 004】输入某年某月某日,判断这一天是这一年的第几天?
----------------------------------------------
这题竟然写了 28 行代码!而且还不包含输入数据的验证(只能假设输入的日期是严格按照格式来的)。但我坚信,一定有更简洁的方法,比如 Python 对日期的处理。
不过反正还没学到这些知识,现在只能用傻大粗的办法解决。等学到高级的办法再来更新吧~~~
思路:先判断是否为闰年,这关系到 2 月份的天数。之后再根据月份值把前几个月的天数累积加起来,最后再加上个“日”,就可以了。
dat = input('请输入某年某月某日,格式为 yyyy-mm-dd :')
y = int(dat[0:4]) #获取年份
m = int(dat[5:7]) #获取月份
d = int(dat[8:]) #获取日 ly = False if y%100 == 0: #若年份能被100整除
if y%400 == 0: #且能被400整除
ly = True #则是闰年
else:
ly = False
elif y%4 == 0: #其它情况下,若能被4整除
ly = True #则为闰年
else:
ly = False if ly == True: #若为闰年,则2月份有29天
ms = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
else:
ms = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31] days = 0
for i in range(1, 13): #从1到12逐一判断,以确定月份
if i == m:
for j in range(i-1): #确定月份i之后,则将ms列表中的前i-1项相加
days += ms[j]
print('%s是该年份的第%s天。' % (dat, (days + d))) #最后再加上“日”,即是答案
请大神帮忙简化下这渣代码。跪谢!
【2016-10-13 更新】-------------------------------------------------------------
查了下文档,发现有个 datetime 的库,似乎可以用来解这题。代码如下:
import datetime y = int(input('请输入4位数字的年份:')) #获取年份
m = int(input('请输入月份:')) #获取月份
d = int(input('请输入是哪一天:')) #获取“日” targetDay = datetime.date(y, m, d) #将输入的日期格式化成标准的日期
print(targetDay - datetime.date(targetDay.year-1, 12, 31)) #减去上一年最后一天,可得解
思路也很简单:获取目标日期,然后减去上一年度的最后一天,就可以得出该日期是当年的第几天。输出结果如下:
请输入4位数字的年份:2016
请输入月份:12
请输入是哪一天:31
366 days, 0:00:00
但就是不知道怎样把这个结果 “366 days, 0:00:00” 处理一下、让只剩下 “366” 这个数值…… datetime库还得多研究研究才行。
【2016-10-13 更新】-------------------------------------------------------------
又好好查了查 官方文档,发现上述代码输出的结果是 datetime.timedelta(),可以用 datetime.timedelta.days 轻松提取天数。更新代码如下:
import datetime y = int(input('请输入4位数字的年份:')) #获取年份
m = int(input('请输入月份:')) #获取月份
d = int(input('请输入是哪一天:')) #获取“日” targetDay = datetime.date(y, m, d) #将输入的日期格式化成标准的日期
dayCount = targetDay - datetime.date(targetDay.year - 1, 12, 31) #减去上一年最后一天
print('%s是%s年的第%s天。'% (targetDay, y, dayCount.days))
输出结果如下:
请输入4位数字的年份:2016
请输入月份:5
请输入是哪一天:1
2016-05-01是2016年的第122天。
当然,正式用的时候,肯定还得验证输入字符的合理性,比如月份只能是 range(1,13),再比如如果是闰年且月份为2,则“天”只能是 range(1,29)等等,这里就不多写了~~~
++++++++++++++++++++++++++++++++++++++++++++++