Python 웹 스크랩 핑-CAPTCHA 처리
이 장에서는 인간 또는 로봇에 대한 사용자 테스트에 사용되는 웹 스크래핑 및 CAPTCHA 처리를 수행하는 방법을 이해하겠습니다.
CAPTCHA 란 무엇입니까?
CAPTCHA의 전체 형식은 다음과 같습니다. Completely Automated Public Turing test to tell Computers and Humans Apart, 이는 사용자가 인간인지 아닌지를 확인하기위한 테스트임을 분명히 나타냅니다.
CAPTCHA는 일반적으로 컴퓨터 프로그램으로 감지하기 쉽지 않지만 사람이 어떻게 든 이해할 수있는 왜곡 된 이미지입니다. 대부분의 웹 사이트는 봇이 상호 작용하지 못하도록 CAPTCHA를 사용합니다.
Python으로 CAPTCHA로드
웹 사이트에 등록하고 CAPTCHA가있는 양식이 있다고 가정하고 CAPTCHA 이미지를로드하기 전에 양식에 필요한 특정 정보에 대해 알아야합니다. 다음 Python 스크립트의 도움으로 우리는 웹 사이트에서 등록 양식의 양식 요구 사항을 이해할 수 있습니다.http://example.webscrapping.com.
import lxml.html
import urllib.request as urllib2
import pprint
import http.cookiejar as cookielib
def form_parsing(html):
tree = lxml.html.fromstring(html)
data = {}
for e in tree.cssselect('form input'):
if e.get('name'):
data[e.get('name')] = e.get('value')
return data
REGISTER_URL = '<a target="_blank" rel="nofollow"
href="http://example.webscraping.com/user/register">http://example.webscraping.com/user/register'</a>
ckj = cookielib.CookieJar()
browser = urllib2.build_opener(urllib2.HTTPCookieProcessor(ckj))
html = browser.open(
'<a target="_blank" rel="nofollow"
href="http://example.webscraping.com/places/default/user/register?_next">
http://example.webscraping.com/places/default/user/register?_next</a> = /places/default/index'
).read()
form = form_parsing(html)
pprint.pprint(form)
위의 Python 스크립트에서 먼저 lxml python 모듈을 사용하여 양식을 구문 분석하는 함수를 정의한 다음 다음과 같이 양식 요구 사항을 인쇄합니다.
{
'_formkey': '5e306d73-5774-4146-a94e-3541f22c95ab',
'_formname': 'register',
'_next': '/places/default/index',
'email': '',
'first_name': '',
'last_name': '',
'password': '',
'password_two': '',
'recaptcha_response_field': None
}
위의 출력에서 다음을 제외한 모든 정보를 확인할 수 있습니다. recpatcha_response_field이해하기 쉽고 간단합니다. 이제이 복잡한 정보를 어떻게 처리하고 CAPTCHA를 다운로드 할 수 있는지에 대한 의문이 생깁니다. 다음과 같이 pillow Python 라이브러리를 사용하여 수행 할 수 있습니다.
필로우 파이썬 패키지
Pillow는 이미지 조작에 유용한 기능을 가진 Python 이미지 라이브러리의 포크입니다. 다음 명령을 사용하여 설치할 수 있습니다.
pip install pillow
다음 예에서는 CAPTCHA를로드하는 데 사용합니다.
from io import BytesIO
import lxml.html
from PIL import Image
def load_captcha(html):
tree = lxml.html.fromstring(html)
img_data = tree.cssselect('div#recaptcha img')[0].get('src')
img_data = img_data.partition(',')[-1]
binary_img_data = img_data.decode('base64')
file_like = BytesIO(binary_img_data)
img = Image.open(file_like)
return img
위의 파이썬 스크립트는 pillowpython 패키지 및 CAPTCHA 이미지로드를위한 함수 정의. 이름이 지정된 함수와 함께 사용해야합니다.form_parser()등록 양식에 대한 정보를 얻기 위해 이전 스크립트에 정의되어 있습니다. 이 스크립트는 CAPTCHA 이미지를 유용한 형식으로 저장하여 추가로 문자열로 추출 할 수 있습니다.
OCR : Python을 사용하여 이미지에서 텍스트 추출
CAPTCHA를 유용한 형식으로로드 한 후 이미지에서 텍스트를 추출하는 프로세스 인 OCR (Optical Character Recognition)을 사용하여 추출 할 수 있습니다. 이를 위해 우리는 오픈 소스 Tesseract OCR 엔진을 사용할 것입니다. 다음 명령을 사용하여 설치할 수 있습니다.
pip install pytesseract
예
여기에서는 Pillow Python Package를 사용하여 CAPTCHA를로드 한 위의 Python 스크립트를 다음과 같이 확장합니다.
import pytesseract
img = get_captcha(html)
img.save('captcha_original.png')
gray = img.convert('L')
gray.save('captcha_gray.png')
bw = gray.point(lambda x: 0 if x < 1 else 255, '1')
bw.save('captcha_thresholded.png')
위의 Python 스크립트는 다음과 같이 명확하고 tesseract에 전달하기 쉬운 흑백 모드로 CAPTCHA를 읽습니다.
pytesseract.image_to_string(bw)
위의 스크립트를 실행하면 등록 양식의 CAPTCHA가 출력으로 표시됩니다.