Answer the question
In order to leave comments, you need to log in
How to parse data from multiple pages?
There is a site that has a section with the page_listing class. It is necessary to extract links from this section that are in the list with different classes. All links on the site have the same rel="nofollow" attribute, so this attribute cannot be parsed from many pages. The parser quietly parses the first page.
import requests
from bs4 import BeautifulSoup as bs
import csv
headers = {'accept' : '*/*', 'user-agent' : 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/72.0.3626.119 Safari/537.36'}
base_url = 'https://www.citilink.ru/catalog/computers_and_notebooks/parts/cpu/?available=1&status=55395790&p=1'
def find_content(base_url, headers):
urls = []
urls.append(base_url)
session = requests.Session()
request = session.get(base_url, headers=headers)
if request.status_code == 200:
request = session.get(base_url, headers=headers)
soup = bs(request.content, 'lxml')
try:
pagination = soup.findAll('a', attrs={'rel' : 'nofollow'})
count = int(pagintaion[-1].text)
except:
pass
for url in urls:
request = session.get(url, headers=headers)
soup = bs(request.content, 'lxml')
divs = soup.findAll('div', attrs={'class' : 'subcategory-product-item'})
for div in divs:
title = div.find('a', attrs={'class' : 'ddl_product_link'}).text
href = div.find('a', attrs={'class' : 'ddl_product_link'})['href']
about = div.find('p', attrs={'class' : 'short_description'}).text
stand_price = div.find('span', attrs={'class' : 'subcategory-product-item__price_standart'}).text
try:
special_price = div.find('span', attrs={'class' : 'subcategory-product-item__price_special'}).text
except:
special_price = '-'
pass
all = title + '\n' + href + '\n' + about + '\n' + 'Стандартная цена: ' + stand_price + '\n' + 'Специальная цена: ' + str(special_price) + '\n\n\n\n'
print(all)
#for i in pagination:
# print(i)
find_content(base_url, headers)
Answer the question
In order to leave comments, you need to log in
base_url = 'https://www.citilink.ru/catalog/computers_and_notebooks/computers/?available=1&status=55395790&p={}'
urls = [base_url.format(x) for x in range (1, total_pages+1)]
Didn't find what you were looking for?
Ask your questionAsk a Question
731 491 924 answers to any question