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

发布时间:2019-03-16 00:01:23编辑:auto阅读(1929)

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

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

        没有封装,流水账式写法,比较简陋,各位客官(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()

     

关键字