我见过这样的问题问了很多次,但没有一个是有帮助的。
我正在尝试将数据提交到web上的表单,尝试过的请求和urllib都没有成功。
例如,下面的代码应该在SO上搜索python标记:
import urllib
import urllib2
url = 'http://stackoverflow.com/'
# Prepare the data
values = {'q' : '[python]'}
data = urllib.urlencode(values)
# Send HTTP POST request
req = urllib2.Request(url, data)
response = urllib2.urlopen(req)
html = response.read()
# Print the result
print html
然而,当我运行它时,我得到了主页的html源代码。
以下是使用请求的示例:
import requests
data= {
'q': '[python]'
}
r = requests.get('http://stackoverflow.com', data=data)
print r.text
同样的结果!我不明白为什么这些方法不起作用,我已经在不同的网站上尝试过,但都没有成功,所以如果有人成功做到了这一点,请告诉我怎么做!
非常感谢!
发布于 2015-01-22 03:30:19
import urllib
import urllib2
url = 'http://www.someserver.com/cgi-bin/register.cgi'
values = {'name' : 'Michael Foord',
'location' : 'Northampton',
'language' : 'Python' }
data = urllib.urlencode(values)
req = urllib2.Request(url, data)
response = urllib2.urlopen(req)
the_page = response.read()
这将使用值中指定的数据发出POST请求。我们需要urllib对url进行编码,然后使用urllib2发送请求。
发布于 2017-07-15 19:34:44
来自python的机械化库也很棒,它甚至允许你提交表单。您可以使用以下代码来创建浏览器对象和创建请求。
import mechanize,re
br = mechanize.Browser()
br.set_handle_robots(False) # ignore robots
br.set_handle_refresh(False) # can sometimes hang without this
br.addheaders = [('User-agent', 'Firefox')]
br.open( "http://google.com" )
br.select_form( 'f' )
br.form[ 'q' ] = 'foo'
br.submit()
resp = None
for link in br.links():
siteMatch = re.compile( 'www.foofighters.com' ).search( link.url )
if siteMatch:
resp = br.follow_link( link )
break
content = resp.get_data()
print content
https://stackoverflow.com/questions/17509607
复制相似问题