我试图用一个循环建立一个url列表,然后从每个url中获取一个数据点,但它似乎只对列表的最后一项(MMM)执行此操作,而不是所有的项……我做错了什么?谢谢!
from simplified_scrapy.request import req
from simplified_scrapy.simplified_doc import SimplifiedDoc
tickers = ['AAPL','T','MMM']
for i in tickers:
quote_page = ['https://ycharts.com/companies/'+i+'/dividend_yield']
data = []
for pg in quote_page:
page = req.get(pg)
doc = SimplifiedDoc(page)
divyield = doc.select('.box boxRatio').getElementByText('Average').next.text
data.append((divyield)[:-1])
print (data)发布于 2020-01-20 00:47:39
当你执行
for i in tickers:
quote_page = ['https://ycharts.com/companies/'+i+'/dividend_yield']您创建了一个循环,并且在该循环的每次迭代中,您将新值(一个包含1个元素的数组)赋给quote_page,而不是将新值附加到数组quote_page。
您可以执行以下操作:
quote_page = []
for i in tickers:
quote_page.append('https://ycharts.com/companies/'+i+'/dividend_yield')或者你可以使用@DarrylG在评论中建议的更短的变体:
quote_page = ['https://ycharts.com/companies/'+i+'/dividend_yield' for i in tickers]https://stackoverflow.com/questions/59812122
复制相似问题