0

我被这个问题困扰了很多天。

 a = pd.date_range(start= '02/02/2017', end='06/02/2018', freq = 'D')
 c = a.format(formatter=lambda x: x.strftime('%Y-%m-%d'))

    for date_to in c:
        date_to= date_to
        print("date_to has been picked up")
        b = pd.date_range(start= '02/01/2017', end='06/2/2018', freq = 'D')
        d = b.format(formatter=lambda x: x.strftime('%Y-%m-%d'))
        for date_from in d:
            date_from= date_from
            print('date_from has been picked up')
            df = ek.get_news_headlines('R:AAPL.O AND Language:LEN', date_from = date_from , date_to = date_to, count=100)

这是我为从第三方 API 中提取新闻而编写的上述代码(在最后一行代码中)我面临的问题是,在最后一行中,我必须提供 date_from 和 date_to 来提供提取数据的日期范围。现在我想每次都自动更改日期范围,就像我们在循环中所做的那样。最后一个循环“date_from”正在工作,但第一个循环没有提供“date_to”。预先感谢您的合作

4

1 回答 1

1

您的问题有点不清楚,但我认为这是您想要实现的目标 - 同时获取一对日期并移动到下一对(n 次迭代),而不是两个嵌套的 for 循环(n 2次迭代):

#Create date lists first
a = pd.date_range(start= '02/02/2017', end='06/02/2018', freq = 'D')
b = pd.date_range(start= '02/01/2017', end='06/2/2018', freq = 'D')
c = a.format(formatter=lambda x: x.strftime('%Y-%m-%d'))
d = b.format(formatter=lambda x: x.strftime('%Y-%m-%d'))

# Single for loop iterating over pairs of elements of c,d
for date_to,date_from in zip(c,d): 
    print("date_to has been picked up")
    print('date_from has been picked up')
    df = ek.get_news_headlines('R:AAPL.O AND Language:LEN', date_from = date_from , date_to = date_to, count=100)

您可能想了解如何zip()工作:

https://docs.python.org/3.4/library/functions.html#zip

于 2018-06-04T13:32:39.793 回答