작성
·
185
0
안녕하세요! 크롤링 진행중입니다!
제가 keyword 변수에 gui 를 사용해서 검색어를 input하는 방식으로 이용중입니다.
그냥 경로를 넣었을 때는 검색어가 잘 나오는데, gui를 사용하면 다른 내용이 나옵니다. 저의 결과로는 책을 크롤링해오고 있습니다.. 무엇이 문제일까요 ㅠㅠ
import requests
from bs4 import BeautifulSoup
import time
import pyautogui
keyword = pyautogui.prompt('검색어를 입력하세요.')
path = 'https://www.coupang.com/np/search?q={keyword}&channel=recent'
# 헤더에 User-Agent, Accept-Language 를 추가하지 않으면 멈춤
header = {
'Host': 'www.coupang.com',
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:76.0) Gecko/20100101 Firefox/76.0',
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8',
'Accept-Language': 'ko-KR,ko;q=0.8,en-US;q=0.5,en;q=0.3',
}
response_1 = requests.get(path, headers=header)
html = response_1.text
soup_1 = BeautifulSoup(html, 'html.parser')
links = soup_1.select('a.search-product-link')
for link in links:
# 광고상품 제거
if len(link.select('span.ad-badge-text')) > 0:
print('광고 상품 입니다.')
else:
sub_path = 'https://www.coupang.com/' + link.attrs['href']
# print(sub_path)
response_2 = requests.get(sub_path, headers=header)
html = response_2.text
soup_2 = BeautifulSoup(html, 'html.parser')
# 회사 - 있을 수도 있고, 없을 수도 있음.
# 중고상품은 태그가 달라짐
try:
brand_name = soup_2.select_one('a.prod-brand-name').text
except:
brand_name = ""
# 제품명
product_name = soup_2.select_one('h2.prod-buy-header__title').text
# 가격
try:
product_price = soup_2.select_one('span.total-price > strong').text
except:
product_price = 0
print(brand_name, product_name, product_price)
print('\nDvlp.H.Y.C.Sol\n')
답변 2
0
f-string 으로 바꾸어 주셔야 해요 ㅎㅎ
path = f'https://www.coupang.com/np/search?q={keyword}&channel=recent'
0
안녕하세요 찬솔님, 인프런 AI 인턴이에요.
문제의 원인은 pyautogui.prompt()
함수를 사용하여 검색어를 입력받아 path
변수에 넣어주려고 하실 때 발생한 것 같습니다. path
변수에 넣어야하는 값을 바르게 전달해주기 위해서는 format()
메소드를 사용하거나 f-string을 활용하셔야 합니다.
예를 들어, path
변수를 아래와 같은 방식으로 수정하셔야 합니다.
path = f'https://www.coupang.com/np/search?q={keyword}&channel=recent'
# 또는
path = 'https://www.coupang.com/np/search?q={}&channel=recent'.format(keyword)
변경된 코드로 다시 실행하시면 예상대로 검색어가 적용된 페이지로 접근할 수 있을 것입니다. 문제점 해결에 도움이 되었길 바랍니다. 감사합니다!
오 이거는 정확한 답변 인데요?
AI인턴 요건 잘해주네