爬取博客园有关爬虫的文章

    最近自己的测试小圈子里都在讨论爬虫,发现我装逼都困难了许多,所以决定快速补充一下这方面的东西。

    到网上找了点视频,实在是看不进去(主要是对装逼没有什么帮助),然后又由于略微懒得原因就写了这个小东西。

    没有封装,流水账式写法,比较简陋,各位客官(dalao)见谅。

 1 # coding: utf-8
 2 import requests
 3 from bs4 import BeautifulSoup
 4 # 定义变量,这里可以用一个
 5 d = 1
 6 p = 0
 7 k = 0
 8 Reptilian_url = []
 9 Reptilian_title = []
10 # 打开session
11 s = requests.session()
12 # 伪装头部
13 h = {
14     'user-agent':'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 UBrowser/6.2.4094.1 Safari/537.36',
15     'accept-encoding':'gzip, deflate, br'
16 }
17 # 从第1页到最大页数的url,总共有200页,这个数值也可以从页面读取
18 while d in range(200):
19     url = 'https://www.cnblogs.com/cate/python/%d'% d
20     r = s.get(url, headers=h)
21     t = r.text
22     soup = BeautifulSoup(t, 'lxml')
23     list = soup.select('div.post_item_body h3')
24     list2 = soup.find_all(attrs={'class':"titlelnk"})
25     while p < d:
26         # 把标题写入空列表
27         for z1 in list:
28             Reptilian_title.append(z1.string)
29         # 把url写入空列表
30         for u1 in list2:
31             Reptilian_url.append(u1['href'])
32         p += 1
33     d += 1
34 # 打印爬取的总数据量
35 print(len(Reptilian_title))
36 # 加入筛选条件,包含爬虫字段的帖子
37 while k < len(Reptilian_title):
38     if '爬虫' in Reptilian_title[k]:
39         print(k+1,'%s'%Reptilian_title[k],'','%s'%Reptilian_url[k])
40         print('===============================')
41     k += 1

    可以给中间加一小段,写到文档里,保存下来偷偷看。

1 Reptilian = open('1.txt', 'a')
2 Reptilian.writelines(['标题:',Reptilian_title,' ','url:',Reptilian_url])
3 Reptilian.close()

 

posted on 2018-10-08 10:20  妖小华  阅读(491)  评论(0编辑  收藏  举报

导航