Google 画像検索の結果の解析に問題があります。でやってみましたselenium webdriver
。100件の結果が返ってきましたが、かなり遅かったです。モジュールを含むページをリクエストすることにしましたが、requests
結果が 20 件しか返されませんでした。同じ 100 件の結果を得るにはどうすればよいですか? ページネーションなどの方法はありますか?
これはselenium
コードです:
_url = r'imgurl=([^&]+)&'
for search_url in lines:
driver.get(normalize_search_url(search_url))
images = driver.find_elements(By.XPATH, u"//div[@class='rg_di']")
print "{0} results for {1}".format(len(images), ' '.join(driver.title.split(' ')[:-3]))
with open('urls/{0}.txt'.format(search_url.strip().replace('\t', '_')), 'ab') as f:
for image in images:
url = image.find_element(By.TAG_NAME, u"a")
u = re.findall(_url, url.get_attribute("href"))
for item in u:
f.write(item)
f.write('\n')
requests
コード は次のとおりです。
_url = r'imgurl=([^&]+)&'
for search_url in lines[:10]:
print normalize_search_url(search_url)
links = 0
request = requests.get(normalize_search_url(search_url))
soup = BeautifulSoup(request.text)
file = 'cars2/{0}.txt'.format(search_url.strip().replace(' ', '_'))
with open(file, 'ab') as f:
for image in soup.find_all('a'):
if 'imgurl' in image.get('href'):
links += 1
u = re.findall(_url, image.get("href"))
for item in u:
f.write(item)
f.write('\n')
print item
print "{0} links extracted for {1}".format(links, ' '.join(soup.title.name.split(' ')[:-3]))