zoukankan      html  css  js  c++  java
  • 线程池的异步爬取

    线程池的异步爬取

    import requests
    from lxml import etree
    url = 'https://www.qiushibaike.com/text/page/%d/'
    urls = []
    for page in range(1,11):
        new_url = format(url%page)
        urls.append(new_url)
    
    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.100 Safari/537.36"
    }
    #该函数只可以有一个参数
    def get_request(url):
        '''
        :param url: 每个页面url
        :return: 每个页面的所有作者
        '''
        author_list = []
        res =requests.get(url,headers=headers).text
        tree = etree.HTML(res)
        div_list = tree.xpath('//*[@id="content-left"]/div')
        for div in div_list:
            author = div.xpath('./div[1]/a[2]/h2/text() | ./div[1]/span[2]/h2/text()')
            author_list.append(author)
        return author_list
    
    from multiprocessing.dummy import Pool
    pool = Pool(10)
    response_test_list = pool.map(get_request,urls)#自定义函数,列表或者字典
    
    print(sum(sum(response_test_list,[]),[]))
    
  • 相关阅读:
    andorid UI事件 监听器
    12小时进制的时间输出的编辑代码
    Java运算符
    运算符的优先级
    UTF-8
    对ASCII的了解
    数组
    Java语法基础
    Java的跨平台
    指针的了解
  • 原文地址:https://www.cnblogs.com/xujunkai/p/11424790.html
Copyright © 2011-2022 走看看