多线程爬取博拾贝

from bs4 import BeautifulSoup
from urllib import request
import threading
import re
import os
from lxml import html

class SpiderCategory(threading.Thread): #继承父类threading.Thread

    def __init__(self,url,newdir,CrawledURLs):
        super(SpiderCategory,self).__init__()
        self.url = url
        self.newdir = newdir
        self.CrawledURLs = CrawledURLs

    def run(self): #把要执行的代码写到run函数里面,线程在创建后会直接运行run函数
        CrawListPage(self.url, self.newdir, self.CrawledURLs)

starturl = "https://bh.sb/post/category/main/"
#判断地址是否已经爬取
def __isexit(newurl,CrawledURLs):
    for url in CrawledURLs:
        if newurl == url:
            return True
    return False


#打开页面
def getUrl(url):
    req = request.Request(url)
    html = request.urlopen(req).read()
    html = html.decode('utf-8')
    req.add_header('User-Agent','Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.163 Safari/537.36')
    return html

#SpiderCategory().getUrl('https://bh.sb/post/category/main/')

#分析主题下的页面
def CrawListPage(indexurl,filedir,CrawledURLs):
    print('正在解析主题下资源')
    page = getUrl(indexurl)

    if page == 'error':
        return
    CrawledURLs.append(indexurl)

    etree = html.etree
    Html = etree.HTML(page)

    p_title = Html.xpath('//article[@class="article-content"]/p')[:-5]
    p_image = Html.xpath('//article[@class="article-content"]/p/img/@src')
    i=0
    for img_url in p_image:
        img_url_name = '.'+(img_url.split('.')[-1])
        img_file_name = filedir+"/"+str(i)+img_url_name
        print(img_file_name)
        with open(img_file_name,"wb") as f:
            print(img_url)
            req = request.urlopen(img_url)
            print("req",req)
            buf = req.read()
            print(buf)
            f.write(buf)
            i +=1
    # title_len = len(p_title)
    # print(title_len)
    # for i in range(0,title_len):
    #
    #
    #     #print(p_title[i].xpath("img/@src"))
    #     if not p_title[i].xpath("text()"):
    #         img = p_title[i].xpath("img/@src")
    #         source = p_title[i-1].xpath("text()")[0].replace("/", " ") \
    #                                             .replace("\\", " ") \
    #                                             .replace(":", " ") \
    #                                             .replace("*", " ") \
    #                                             .replace("?", " ") \
    #                                             .replace("\"", " ") \
    #                                             .replace("<", " ") \
    #                                             .replace(">", " ") \
    #                                             .replace("|", " ") \
    #                                             .replace("【", " ") \
    #                                             .replace("】", " ")
    #         img_name = source.strip()+img[0]
    #         # print(img_name)
    #
    #         #filedir_img = str(filedir+"//"+img_name+'.jpg').strip()
#解析首页
def CrawIndexPage(starturl):
    print("正在爬取首页")

    page = getUrl(starturl)
    if page =="error":
        return

    soup = BeautifulSoup(page,'lxml')
    Nodes = soup.find_all('article')

    print("首页解析出地址",len(Nodes),"条")
    for node in Nodes:
        CrawledURLs = []
        CrawledURLs.append(starturl)
        a = node.find('a')
        url = a.get('href')

        if __isexit(url,CrawledURLs):
            pass

        else:
            try:
                catalog = a.text

                catalog = re.findall(r'\[(.*?)\]',catalog)[0]
                print("---------------",catalog)
                newdir = "D:/海贝/"+catalog
                if not os.path.exists(newdir):
                    os.makedirs(newdir.encode("utf-8"))
                print("创建分类目录成功----------")

                thread = SpiderCategory(url,newdir,CrawledURLs)
                thread.start()
                #CrawListPage(url,newdir,CrawledURLs)
            except Exception as e:
                print(e)
CrawIndexPage(starturl)
posted @ 2020-04-05 23:38  智、心  阅读(125)  评论(0编辑  收藏  举报