用Flask写个爬虫玩

昨天彭老师和我说,希望我能和大家分享一下Flask这一块。碰巧最近在做flask的开发工作,手头上的这个工程项目可以拿出来和大家分享一下。

首先看一下我这个项目的结构

微信截图_20170603120704.png

app文件夹里是放功能模块的,Login是我写的登录模块,crawler是爬取单个页面修改网页源码返回前端的功能模块。其他的那些模块,是其他同事写的。我也不造他们写的什么。templates按理来说应该放的是网页的模板,但由于我们的开发工作是前后端分离的。所以里面放的只是邮件内容的模板。可能部分童鞋不理解什么是前后端分离。

微信截图_20170603122048.png
微信截图_20170603122107.png

上面两张图网站挺漂亮吧?但是,跟我的项目一毛钱关系没有。我整个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参数,就把网页的源码爬回来进行样式的修改,留作后续使用。

微信截图_20170603141815.png

来看看返回的页面

微信截图_20170603141905.png

这是修改过网页源码的页面,绿色的框框是在前端那里选择元素使用的,然后保存到数据库。之后前端那里点个确认按钮,就调用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,保存为<userId>_<_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'

看看后台爬虫项目

微信截图_20170603144038.png

这里我就不使用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()

需要爬取的数据已经在数据库了,通过调用这个接口传入参数,我们的后台爬虫就可以正式跑起来了!

微信截图_20170603142820.png

看看终端

微信截图_20170603143042.png

scrapy爬虫就这样通过flask跑起来了!
不过后面的爬虫数据爬取状态还没写完,所以无法展示效果。

暂时,就到此为止吧

这不是一个教程文章,这篇文章的目的主要是分享一下用flask来运行爬虫项目的思路,所以很多细节的东西,包括怎么使用flask的我也不写了,网上都有教程的。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 131,965评论 20 560
  • 总结 | 反思 | 分享 学习Python爬虫2个月了,一路惊喜一路bug,苦辣酸甜不言中。今天正好周末,做一下阶...
    Wakingup88688阅读 1,981评论 7 73
  • 今天几乎没有联系,除了我分享张德芬的如何才能幸福的视频给他,他回复一个憨笑表情。 他的朋友吴最近经常跟我说他和...
    花间集阅读 31评论 0 0
  • 我曾经是一名新媒体编辑,所在的行业是冷门的建筑辅材。这里要说一下,建材分为主材和辅材,那些你在装修好的房子里看不到...
    夏震阅读 242评论 0 1
  • 风雨夜归人 小时候,第一次最远时间的离家,是去城里上学。那天傍晚,坐上父亲的摩...
    暖暖的南极阅读 101评论 0 1