Python 3:HTTP错误405:不允许的方法

问题描述 投票:1回答:2

我收到'HTTP错误405:方法不允许'错误。我的代码是

import urllib.request
import urllib.parse

try:
    url = 'https://www.google.com/search'
    values = {'q': 'python programming tutorials'}

    data = urllib.parse.urlencode(values)
    data = data.encode('utf-8')  # data should be bytes
    headers = {}
    headers['User-Agent'] = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.84 Safari/537.36"
    req = urllib.request.Request(url, data,  headers = headers)
    resp = urllib.request.urlopen(req)
    print("HERE")
    respData = resp.read()
    saveFile = open('withHeaders.txt', 'w')
    saveFile.write(str(respData))
    saveFile.close()
except Exception as e:
    print(e)

我猜错误在于req = urllib.request.Request(url,data,headers = headers)。什么是错误,语法?代码应该改变什么?任何概念上的错误都会纠正我。


编辑

概念:

def URLRequest(url, params, method="GET"):
    if method == "POST":
        return urllib2.Request(url, data=urllib.urlencode(params))
    else:
        return urllib2.Request(url + "?" + urllib.urlencode(params))
python python-3.x https urllib urlopen
2个回答
1
投票

您可以使用Requests库。它比urllib更清洁

import requests
q = 'Whatever you want to search'
url = 'https://www.google.com/search'
response = requests.get(url+'?'+'q='+q)
saveFile = open('response.txt', 'w')
savefile.write(response.text)
savefile.close()

或者如果你想坚持使用urllib,你可以这样做:

import urllib.request
url = 'https://www.google.com/search'
q = 'Search Query'
headers = {'User-Agent': "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.84 Safari/537.36"}
request = urllib.request.Request(url+'?'+'q='+q, headers=headers)
response = urllib.request.urlopen(request).read() # the text of the response is here
saveFile = open('withHeaders.txt', 'w')
saveFile.write(str(response))
saveFile.close()

0
投票

这里参考www.pythonforbeginners

# Importing the module
import urllib.request


# your search text
text="hi google"

# Define the url
url = 'http://www.google.com/#q='+text

# Add your headers
headers = {'User-Agent' : 'Mozilla 5.10'}

# Create the Request. 
request = urllib.request.Request(url, None, headers)

# Getting the response
response = urllib.request.urlopen(request)

# Print the headers
print (response.read())
© www.soinside.com 2019 - 2024. All rights reserved.