用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的我也不写了,网上都有教程的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,324评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,303评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,192评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,555评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,569评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,566评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,927评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,583评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,827评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,590评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,669评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,365评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,941评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,928评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,159评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,880评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,399评论 2 342

推荐阅读更多精彩内容

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