昨天彭老师和我说,希望我能和大家分享一下Flask这一块。碰巧最近在做flask的开发工作,手头上的这个工程项目可以拿出来和大家分享一下。
首先看一下我这个项目的结构
app
文件夹里是放功能模块的,Login是我写的登录模块,crawler是爬取单个页面修改网页源码返回前端的功能模块。其他的那些模块,是其他同事写的。我也不造他们写的什么。templates按理来说应该放的是网页的模板,但由于我们的开发工作是前后端分离的。所以里面放的只是邮件内容的模板。可能部分童鞋不理解什么是前后端分离。
上面两张图网站挺漂亮吧?但是,跟我的项目一毛钱关系没有。我整个flask项目跑起来。。。。。。连一个网页都木有。。。。。。那我这个项目是干什么用的?
我的这个Flask项目是给前端提供接口连接,返回数据给前端使用。前端做的是展示工作,我这里是后端实现的是功能。
crawler
和·sportSpider`这个项目的两个主要功能。crawler是来爬取预览页,修改样式后在前端那里可以选择要爬取的元素,然后保存到数据库。sportSpider则调用后台scrapy爬虫项目,正式把爬虫跑起来!
直接看我写的那个crawler
模块
# -*- coding: utf-8 -*-
from flask import Flask
from flask_cors import *
from . import crawler
from flask import Flask, jsonify,request,make_response,flash,redirect,url_for
from flask_login import login_user, logout_user, login_required, \
current_user
from lxml import etree
import json
from bs4 import BeautifulSoup
import requests
import re
@crawler.route('/', methods=['GET'])
@cross_origin()
#@login_required
def Crawler():
#url = request.form['url']
url = request.args['url']
print url
headers = {'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:53.0) Gecko/20100101 Firefox/53.0',
'Accept - Language': 'zh - CN, zh;q = 0.8, en - US;q = 0.5, en;q = 0.3',
}
response = requests.get(url).text
soup= BeautifulSoup(response,'html.parser')
new_tag = soup.new_tag("style")
content = """ .io-cursor-not-allowed-CHFG {
cursor: url() 0 0, auto !important;
}
.io-cursor-add-CHFG {
cursor: url() 0 0, auto !important;
}
.io-cursor-delete-CHFG {
cursor: url() 0 0, auto !important;
}
.light-green{border: 3px solid rgba(60, 147, 51, 1) !important;box-sizing: border-box;}"""
soup.head.append(new_tag)
soup.head.style.append(content)
scriptTag = soup.new_tag("script",src='http://crawww.oss-cn-shenzhen.aliyuncs.com/console/build/js/transformer.js')
#scriptContent = 'src="http://crawww.oss-cn-shenzhen.aliyuncs.com/console/build/js/transformer.js"'
soup.body.append(scriptTag)
#soup.body.script.append(scriptContent)
res = soup.prettify()
clsname = re.findall(r'class=".*?"', res)
newclsname = []
for i in clsname:
if i not in newclsname:
newclsname.append(i)
for j in newclsname:
css = re.findall(r'"(.*?)"', j)[0]
res = res.replace(j, ' class="%s io-cursor-add-CHFG light"' % css)
file = open('crawler.html', 'w')
file.write(res.encode('utf-8'))
file.close()
return res
这个API接口是个爬虫,传入url参数,就把网页的源码爬回来进行样式的修改,留作后续使用。
来看看返回的页面
这是修改过网页源码的页面,绿色的框框是在前端那里选择元素使用的,然后保存到数据库。之后前端那里点个确认按钮,就调用sportSpider
这个接口,把后台爬虫激活,让爬虫正式跑起来。
这是sportSpider
的部分代码
@sportSpiders.route('/run', methods=['POST'])
@cross_origin()
def run():
# 接收userId,_id(爬虫id)
userId = request.form['userId']
_id = request.form['_id']
#===========================================================================
# 运行爬虫,记得配置日志文件目录
#===========================================================================
# 爬虫文件放在哪里?用requests写,爬虫文件为sportSpider.py,保存为_<_id>.out日志文件
# os.system('nohup python C:\Users\lenovo\crawler {} 2>&1 > ~/logPath/{}_{}.out &'.format(_id, userId, _id))
os.chdir('C:\Users\lenovo\crawler')#必须切换目录,不然爬虫跑不起来
os.system('python scripts.py {} &'.format(userId))#执行命令,让爬虫启动
# time.sleep(2)
# process = os.popen('cat ~/Desktop/crawservice/crawwwservice/{}_{}.out'.format(userId, _id))
# res = {'message':process.read(),'code':200}
res = {'message':'run success','code':200}
return json.dumps(res)
if __name__ == '__main__':
print 'heeheh'
看看后台爬虫项目
这里我就不使用
scrapy crawl myspider
这条命令来运行爬虫,而是通过
scripts.py
这个脚本让爬虫跑起来
from scrapy.crawler import CrawlerProcess
from scrapy.utils.project import get_project_settings
import sys
args = sys.argv
_id= args[1]
print _id
process = CrawlerProcess(get_project_settings())
print get_project_settings()
name = ['myspider']
#for i in name:
# process.crawl(i,userid='leon')
# process.start()
process.crawl('myspider',_id)
process.start()
需要爬取的数据已经在数据库了,通过调用这个接口传入参数,我们的后台爬虫就可以正式跑起来了!
看看终端
scrapy爬虫就这样通过flask跑起来了!
不过后面的爬虫数据爬取状态还没写完,所以无法展示效果。
暂时,就到此为止吧
这不是一个教程文章,这篇文章的目的主要是分享一下用flask来运行爬虫项目的思路,所以很多细节的东西,包括怎么使用flask的我也不写了,网上都有教程的。