Python爬虫之路-多进程爬取在线课程并存入MySQL数据库

使用多进程的方式可以提高爬取数的效率。
在Python中,multiprocessing模块可是实现多进程。
该模块实现多进程有几种方式,例如Process多进程类和Pool进程池等。
本次使用Pool进程池的方式来实现多进程的工能。
主要流程如下:

 创建进程池
首先实例化Pool()类,然后调用pool实例对象的map方法,这里需要传递2个参数,第一个参数main是进程要执行的函数,第二个参数index是当前页码索引。代码如下:

01	pool = Pool() # 开启进程
02	index = ([x for x in range(totlePageCount)]) # 生成当前页码元组
03	pool.map(main, index) # 执行多进程
04	pool.close() # 关闭进程
05	pool.join()  # 等待子进程结束

 创建进程执行函数
pool.map()方法中定义了一个要执行的方法参数main,接下来是需要定义main()函数。代码如下:

06	def main(index):
07	    # 获取JSON格式数据
08	    content_json = get_json(index)
09	    # 获取课程内容
10	    content = get_content(content_json)
11	    # 保存到数据库
12	    save_mysql(content)

实例代码

import requests
import time
import pymysql
from multiprocessing import Pool

#连接数据库
conn = pymysql.connect(host='localhost',
                port=3306,
                user='root',
                passwd='root',
                db='spider',
                charset='utf8')
cur = conn
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值