3

私はこのサイトを閲覧しました: http://ctrlq.org/screenshots/そして、このページのフォームが、私たちが与えた任意の URL の Web ページのスクリーンショットを提供できることを発見しました。

ここで、mechanize を使用して同じことを試して、python コードを介してフォームを送信することで達成できるかどうかを確認したいと思います。

フォームの送信が成功した場合、取得する必要があります

おめでとうございます。http: //www.gnu.org のスクリーンショット イメージが用意されました。画像をダウンロード

しかし、私の送信は期待どおりの結果を得ることができませんでした。どこが間違っていますか?

コードは次のとおりです。

import mechanize
import cookielib
from BeautifulSoup import BeautifulSoup
import re


# Browser
br = mechanize.Browser()

# Cookie Jar
cj = cookielib.LWPCookieJar()
br.set_cookiejar(cj)

# Browser options
br.set_handle_equiv(True)
#br.set_handle_gzip(True)
br.set_handle_redirect(True)
br.set_handle_referer(True)
br.set_handle_robots(False)

# Follows refresh 0 but not hangs on refresh > 0
br.set_handle_refresh(mechanize._http.HTTPRefreshProcessor(), max_time=1)

# User-Agent (this is cheating, ok?)
br.addheaders = [('User-agent', 'Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.9.0.1) Gecko/2008071615 Fedora/3.0.1-1.fc9 Firefox/3.0.1')]

# The site we will navigate into, handling it's session
br.open('http://ctrlq.org/screenshots/')

html = br.response().read()
soup = BeautifulSoup(html)

hidden_str = str(soup.find('input', { "name" : "labnol" }))
m = re.search('value="(.*?)"', hidden_str)
hidden_val = m.group(1)


print hidden_val


br.select_form(nr=0)

br['url'] = "http%3A%2F%2Fwww.gnu.org"

for form in br.forms():
    print '---------------'
    print form

br.submit()

html2 = br.response().read()


##print html2

print 'if congrat.. exists in result'
print 'congrat' in html2.lower()

そして、ここに結果があります:

>>> ================================ RESTART ================================
>>> 
2f043008c3ecfa0a86ea8a9ed8a19916
---------------
<POST http://ctrlq.org/screenshots/ application/x-www-form-urlencoded
  <TextControl(url=http%3A%2F%2Fwww.gnu.org)>
  <SubmitButtonControl(<None>=) (readonly)>
  <HiddenControl(labnol=2f043008c3ecfa0a86ea8a9ed8a19916) (readonly)>>

False
>>> 

ちなみに、Pythonを使用して指定されたURLのWebページのスクリーンショットを取得する最良の方法は何ですか. pyqt がどのように機能するのかわからないため、pyqt を使用したくありません。組み込みモジュールまたはより単純なモジュールを使用したその他のより単純な代替手段。

4

2 に答える 2

0

Linux マシンでこれを試して、スクリーンショットを自分で自動化することができます。

于 2012-10-24T23:52:11.753 に答える