Python中文
首页
教程
问答
标签
搜索
登录
注册
计算30个工作日中有多少个星期?
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>准确的日期总是很棘手的。我想知道封装30周需要多少周。开始日可以是<strong>星期日的任何一天。<em>周末不能计算在内。</em></p> <p>例如,如果我从2017年11月1日开始,那么在30周内(包括开始日期),结束日期是2017年2月21日。这意味着需要7周的时间。你知道吗</p> <hr/> <p>这就是我尝试过的:</em></p> <p>因为<code>datetime.isocalendar()</code>可以用来确定一年中的周数,所以我的想法是按照以下思路:</p> <p><code>datetime.isocalendar(enddate) - datetime.isocalendar(startdate)</code>。你知道吗</p> <p>但我相信我的结束日期计算是错误的,所以我得到了奇怪的数字:</em></p> <pre><code>import datetime def doit(month, day): startdate = datetime.datetime.strptime("2017-%s-%s" % (month,day),"%Y-%m-%d") enddate = startdate + datetime.timedelta(days=41) print datetime.datetime.isocalendar(enddate)[1] - datetime.datetime.isocalendar(startdate)[1] </code></pre> <p>我知道<code>days=41</code>因为每个星期有两个周末我们不算,所以30个工作日通常是6周,这意味着6*2+30=42天。但由于我们计算的是开始日期,所以我们只增加了<code>42-1=41</code>天。你知道吗</p> <p>为什么我的号码不正确?例如,如果您输入上面列出的日期(<code>doit(1,11)</code>),我将得到<code>6</code>周,这是不正确的。你知道吗</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<pre><code>print datetime.datetime.isocalendar(enddate)[1] - datetime.datetime.isocalendar(startdate)[1] </code></pre> <p>如果工作日是星期一,这个陈述会给你正确的答案!考虑到这种情况,您应该有点不同的想法<strong>开始日可以是一周中的任何一天。</strong></p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
无法使用Django/mongoengine连接到MongoDB(身份验证失败)
4 回答
无法使用Django\u mssql\u后端迁移到外部hos
4 回答
无法使用Django&Python3.4连接到MySql
5 回答
无法使用Django+nginx上载媒体文件
7 回答
无法使用Django1.6导入名称模式
8 回答
无法使用Django1.7和mongodb登录管理站点
4 回答
无法使用Djangoadmin创建项目,进程使用了错误的路径,因为我事先安装了错误的Python
3 回答
无法使用Djangockedi验证CBV中的字段
10 回答
无法使用Djangocketditor上载图像(错误400)
7 回答
无法使用Djangocron进行函数调用
7 回答
无法使用Djangofiler djang上载文件
9 回答
无法使用Djangokronos
6 回答
无法使用Djangomssql provid
5 回答
无法使用Djangomssql连接到带有Django 1.11的MS SQL Server 2016
10 回答
无法使用Djangomssq迁移Django数据库
7 回答
无法使用Djangonox创建用户
5 回答
无法使用Djangopyodb从Django查询SQL Server
9 回答
无法使用Djangopython3ldap连接到ldap
3 回答
无法使用Djangoredis连接到redis
10 回答
无法使用Django中的FK创建新表
5 回答