我有这个问题--看起来很简单,但我就是做不到,我在做一个网络刮擦项目,现在我正在刮一个关键字列表,所以我的代码就像这样打印结果。
Kids Wear Shop
Plastic Children Toys
Balloon
Costumes
Montessori Toys我所要做的就是将这些结果存储在一个列表中,我试图将它们附加到一个列表中,但它将每一行都存储在自己的列表中。
r = requests.get(url)
soup = BeautifulSoup(r.content, 'lxml')
for div in soup.find_all('div', class_='keywords content-div'):
for span in div.find_all('span', class_='keyword key-content'):
for a in span.find_all('a'):
print(a.text)发布于 2022-03-16 12:01:04
find_all()返回所有结果的列表。因此,如果只有一个找到,它将返回一个列表,其中包含一个结果。如果您知道只有一个值,那么使用find()代替。然后,您可以追加该单个值:
r = requests.get(url)
soup = BeautifulSoup(r.content, 'lxml')
lst = []
for div in soup.find_all('div', class_='keywords content-div'):
for span in div.find_all('span', class_='keyword key-content'):
lst.append(span.find('a').text)
print(lst)或者,如果确实存在多个a,则只需将所有内容附加到列表中:
r = requests.get(url)
soup = BeautifulSoup(r.content, 'lxml')
lst = []
for div in soup.find_all('div', class_='keywords content-div'):
for span in div.find_all('span', class_='keyword key-content'):
for a in span.find_all('a'):
lst.append(a.text)
print(lst)或者,在每一步中都将列表连在一起:
r = requests.get(url)
soup = BeautifulSoup(r.content, 'lxml')
lst = []
for div in soup.find_all('div', class_='keywords content-div'):
for span in div.find_all('span', class_='keyword key-content'):
lst += [a.text for a in span.find_all('a')]
print(lst)https://stackoverflow.com/questions/71496576
复制相似问题