day = "13/Oct/2013"
print("Parsing :",day)
day, mon, yr= day.split("/")
sday = yr+" "+day+" "+mon
myday = time.strptime(sday, '%Y %d %b')
Sstart = yr+" "+time.strftime("%U",myday )+" 0"
Send = yr+" "+time.strftime("%U",myday )+" 6"
startweek = time.strptime(Sstart, '%Y %U %w')
endweek = time.strptime(Send, '%Y %U %w')
print("Start of week:",time.strftime("%a, %d %b %Y",startweek))
print("End of week:",time.strftime("%a, %d %b %Y",endweek))
print("Data entered:",time.strftime("%a, %d %b %Y",myday))

out:
Parsing : 13/Oct/2013
Start of week: Sun, 13 Oct 2013
End of week: Sat, 19 Oct 2013
Sun, 13 Oct 2013

在过去的两天里学习过python,并想知道是否有更清洁的方法来执行此方法。此方法看起来很丑陋,每个日期都必须创建一个新的时间变量似乎很愚蠢,并且应该通过一个简单的电话就可以将给定的日期偏移到一周的开始和结束,但是我一直无法在互联网上找到任何看起来可行的文件或文档。

最佳答案

使用datetime模块。

这将产生一周的开始和结束(从星期一到星期日):

from datetime import datetime, timedelta

day = '12/Oct/2013'
dt = datetime.strptime(day, '%d/%b/%Y')
start = dt - timedelta(days=dt.weekday())
end = start + timedelta(days=6)
print(start)
print(end)

编辑:
print(start.strftime('%d/%b/%Y'))
print(end.strftime('%d/%b/%Y'))

关于python - Python:从给定日期开始和结束一周的数据,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/19216334/

10-09 06:58
查看更多