zoukankan      html  css  js  c++  java
  • 多进程 + 多线程抓取博客园信息

    为每个进程分配一定数量的页面,然后在由进程去给线程分配待抓取页面,抓取到信息之后保存到“博客园.csv”文件中。

    第三方模块

    aiohttp : 协程模块

    beautifulsoup4:解析模块

    安装 :

    pip install aiohttp

    pip install beautifulsoup4

    多线程

    asyncio协程模块,通过这模块来启用任务并限制线程数量。线程多了影响效率,因为线程是通过时间分片来模拟并行,进程是真并行

    多进程

    multiprocessing 进程模块通过引用Pool类来启用进程池

    信息保存

    部分代码

    import page
    import asyncio
    import os
    from asyncrequest import AsyncHttp
    from save import db
    from multiprocessing import Pool
    
    # 抓取信息
    async def fetch(url, attach=None):
        reqs = AsyncHttp()
        text = await reqs.request(url, attach)
        items = page.FetchList(text)
        for item in items:
            arc = page.Article(item)
            db.writerow({
                '作者': arc.author,
                '头像': arc.icon,
                '地址': arc.url,
                '标题': arc.title,
                '推荐': arc.digg_num,
                '评论': arc.comment_num,
                '阅读': arc.read_num,
                '发布时间': arc.time
            })
    
    # 协程任务
    async def core(url, s, e):
        cores = [fetch(url + str(n)) for n in range(s, e)]
        await asyncio.gather(*cores)
    
    # 入口
    def main(arg):
        #print(arg[0], arg[1])
        asyncio.Semaphore(3)
        asyncio.run(core('https://www.cnblogs.com/sitehome/p/', arg[0], arg[1]))
    
    
    if __name__ == '__main__':
        with Pool(os.cpu_count()) as p:   # 开启最大进程
            arg = [(1, 10), (10, 20), (20, 30), (30, 40)]  # 采用 1~40页
            rep = p.map_async(main, arg)
            rep.get()

    百度网盘

    链接:https://pan.baidu.com/s/1Iab8Pi1fsfSCMp93sPUX0g
    提取码:4x1u

  • 相关阅读:
    kettle表输入条件参数设置
    batの磕磕碰碰
    bat调用kettle的job文件
    数组转换成字符串输出
    bat调用带参数存储过程
    读取属性文件
    剑指Offer——删除链表中重复的结点
    剑指Offer——链表中环的入口节点
    剑指Offer——两个链表的第一个公共节点
    剑指Offer——表示数值的字符串
  • 原文地址:https://www.cnblogs.com/whnba/p/11597387.html
Copyright © 2011-2022 走看看