Cortando uma lista baseada em eventos entre dois datetimes
-
28-09-2019 - |
Pergunta
Eu tenho uma lista de objeto que, entre outros dados, inclua uma data e preciso criar uma lista de todos os objetos em que essa data cai a qualquer momento no mês passado, ou seja, meia -noite no 1º do mês passado <Dados -alvo <Midnight no 1º deste mês.
Eu também preciso do número de objetos totais que atendem a esses critérios.
No momento, estou fazendo isso em uma série de loops de enquanto, mas sinto que precisa haver uma maneira melhor, principalmente porque meu script está pendurado:
post = 0 #the current post we're analyzing
posts = 0 #the total number of posts in the month we actually care about
lastmonthposts = [] #I think i can just get rid of this
blog = pyblog.WordPress()
date = blog.get_recent_posts(1 + posts)[0]['dateCreated']
while (date > startthismonth):
print "So far, there have been " + str(posts) + " posts this month we've counted."
post = post + 1
date = blog.get_recent_posts(1 + post)[0]['dateCreated']
while (date > startlastmonth):
print "So far, there have been " + str(posts) + " posts last month we've counted, which is " + str(date.timetuple().tm_mon) + "."
posts = posts + 1
post = post + 1
date = blog.get_recent_posts(1 + post)[0]['dateCreated']
lastmonthposts.append('blog')
for blogpost in lastmonthposts:
postnumber = blogpost['postid']
comments = comments + int(blog.get_comment_count(postnumber)['approved'])
Solução
Ao invés de get_recent_posts()
eu usaria get_page_list()
:
from datetime import datetime, timedelta
this_month_start = datetime.now().date().replace(day=1)
prev_month_start = (this_month_start - timedelta(days=1)).replace(day=1)
pages = blog.get_page_list()
last_month_pages = [
p for p in pages
if prev_month_start <= p['dateCreated'] < this_month_start]
last_month_approved_comment_count = sum(
blog.get_comment_count(page['page_id'])['approved']
for page in last_month_pages)
print "number of last month's pages:", len(last_month_pages)
print "number of approved comments for last month's pages:",
print last_month_approved_comment_count
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow