這段代碼以前作業并在網站上輸出了我想要的內容,但后來發生了這個錯誤
from django.shortcuts import render
import json
def get_html_content(fplid):
import requests
API_KEY = "eb9f22abb3158b83c5b1b7f03c325c65"
url = 'https://fantasy.premierleague.com/api/entry/{fplid}/event/30/picks/'
payload = {'api_key': API_KEY, 'url': url}
for _ in range(3):
try:
response = requests.get('http://api.scraperapi.com/', params= payload)
if response.status_code in [200, 404]:
break
except requests.exceptions.ConnectionError:
response = ''
#userdata = json.loads(response.text)
return response.text
def home(request):
if 'fplid' in request.GET:
fplid = request.GET.get('fplid')
html = get_html_content(fplid)
return render(request, 'scrape/home.html', {'fpldata': html})
這是我的views.py 檔案。我想我之前分配了 html,但我不確定,它在呈現之前是如何參考的。我為許多 IP 地址添加了 scraperapi,因為我認為我可能被禁止使用 api。我不確定發生了什么。
<body>
<h1>Enter Your FPL id </h1>
<form method="GET">
<label for="fplid"> </label>
<input type="text", name="fplid", id="fplid"> <br>
<input type="submit" value="Submit" />
</form>
<h3> {{fpldata}}</h3>
</body>
如果相關,這是 home.html 檔案的一部分
uj5u.com熱心網友回復:
當您最初加載頁面時,可能不會有一個已初始化的?fplid=xx. 如果不存在,則不會為變數分配值。
您可以使用或初始化變數html = None:
def home(request):
if 'fplid' in request.GET: # <- when this isnt true
fplid = request.GET.get('fplid')
html = get_html_content(fplid)
return render(request, 'scrape/home.html', {'fpldata': html})
return render(request, 'scrape/home.html')
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/456924.html
上一篇:(初級)Python網頁抓取BeautifulSoup
下一篇:網路抓取口袋妖怪資料
