用类方法写爬虫-爬东野圭吾白夜行小说第一章练手

import requests
import lxml.html
from multiprocessing.dummy import Pool
class Novespider(object):
    def __init__(self):
        self.novel_dict={}
    def get_content(self,url):
        html = requests.get(url).content
        self.get_novel(html)
    def get_novel(self,html):
        secetor = lxml.html.fromstring(html)
        data = secetor.xpath('//div[@class="readtext"]')
        for each_paragraph in data:
            title = each_paragraph.xpath('h4/text()')[0]
            # print(title)
            paragraph = each_paragraph.xpath('p/text()')
            #print(paragraph)
            paragraph = '\n'.join(paragraph)
        self.novel_dict[title]=paragraph
        #novel[title]=paragraph
    def write_txt(self):
        novel_paragraph_list=sorted(self.novel_dict.items(),key=lambda x:x[0])
        with open('东野圭吾.txt','w',encoding='utf-8') as file:
            for i in novel_paragraph_list:
                file.write(i[0])
                file.write('\n')
                file.write(i[1])
                file.write('\n')
if __name__=='__main__':
    urls = ['http://www.dongyeguiwu.com/books/baiyexing/53.html/{}'.format(str(i)) for i in  range(1,8,1)]
    #for i in url:
        #print(i)
    pool = Pool()
    data = Novespider()
    pool.map(data.get_content, urls)
    data.write_txt()
    print('搞掂了')

效果图片

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容