scrapy_novel_python

 1 # _*_ coding:UTF _8_
 2 from bs4 import BeautifulSoup
 3 import requests,sys
 4 class downloader(object):
 5     def __init__(self):
 6         self.server = 'http://www.biqukan.com/'
 7         self.target = 'http://www.biqukan.com//1_1094/'
 8         self.names = []
 9         self.urls = []
10         self.nums = 0
11     #获取下载链接
12     def get_download_url(self):
13         reg = requests.get(url = self.target)
14         html = reg.text
15         div_bf = BeautifulSoup(html)
16         div = div_bf.find_all('div', class_ = 'listmain')
17         a_bf = BeautifulSoup(str(div[0]))
18         a = a_bf.find_all('a')
19         self.nums = len(a[15:])
20         for each in a[15:]:
21             self.names.append(each.string)
22             self.urls.append(self.server + each.get('href'))
23     #获取章节内容
24     def get_contents(self,target):
25         req = requests.get(url = target)
26         html = req.text
27         bf = BeautifulSoup(html)
28         texts = bf.find_all('div',class_ = 'showtxt')
29         texts = texts[0].text.replace('\xa0'*8,'\n\n')
30         return texts
31     #写入文件
32     def writer(self,name,path,text):
33         write_flag = True
34         with open(path,'a',encoding='utf-8') as f:
35             f.write(name + '\n')
36             f.writelines(text)
37             f.write('\n\n')
38 if __name__ == '__main__':
39     dl = downloader()
40     dl.get_download_url()
41     print('《一念永恒》开始下载:')
42     for i in range(dl.nums):
43         dl.writer(dl.names[i],'一念永恒.txt',dl.get_contents(dl.urls[i]))
44         sys.stdout.write("已下载:%.3f%%" % float(i/dl.nums) + '\r')
45         sys.stdout.flush()
46     print('《一念永恒》下载完成')

 

转载于:https://www.cnblogs.com/zysps1/p/novel_scrapy.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值