【发布时间】:2015-07-08 09:25:15
【问题描述】:
这就是我的 routes.py 的样子。基本上它是一个爬虫,它爬取页面内的所有 youtube 视频链接。此代码可以独立运行(不在烧瓶中)。但是,当我尝试通过烧瓶使其工作时,它会引发 500 内部服务器错误。任何形式的帮助将不胜感激。
from flask import Flask, render_template
from BeautifulSoup import BeautifulSoup
import requests
app = Flask(__name__)
@app.route("/")
def main():
url="https://www.youtube.com/user/EminemVEVO/videos"
source_code=requests.get(url)
text_source_code=source_code.text
final_code=BeautifulSoup(text_source_code)
video_url=final_code.findAll('a',{'class':'yt-uix-sessionlink yt-uix-tile-link spf-link yt-ui-ellipsis yt-ui-ellipsis-2'})
for i in video_url:
if "/watch?v=" in i.get('href'):
j= i.get('href')
j=j.replace("/watch?v=","")
print "http://youtube.com"+j
if __name__ == '__main__':
app.run()
堆栈跟踪如下
Traceback (most recent call last):
File "/Library/Python/2.7/site-packages/flask/app.py", line 1836, in __call__
return self.wsgi_app(environ, start_response)
File "/Library/Python/2.7/site-packages/flask/app.py", line 1820, in wsgi_app
response = self.make_response(self.handle_exception(e))
File "/Library/Python/2.7/site-packages/flask/app.py", line 1403, in handle_exception
reraise(exc_type, exc_value, tb)
File "/Library/Python/2.7/site-packages/flask/app.py", line 1817, in wsgi_app
response = self.full_dispatch_request()
File "/Library/Python/2.7/site-packages/flask/app.py", line 1478, in full_dispatch_request
response = self.make_response(rv)
File "/Library/Python/2.7/site-packages/flask/app.py", line 1566, in make_response
raise ValueError('View function did not return a response')
ValueError: View function did not return a response
【问题讨论】:
-
你能添加堆栈跟踪吗?也可能重新格式化代码(虽然还不错)
标签: python flask beautifulsoup web-crawler