爬取Crossin教室ajax异步动态网页django教程内容示例(五)

一、示例代码:

from bs4 import BeautifulSoup
import requests

headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) '
                  'Chrome/117.0.0.0 Safari/537.36',
    'X-Requested-With': 'XMLHttpRequest', }
base_url = 'http://111.230.211.102:8080/static/tasks/djangogirl/'


def pages_parse(page):
    page_url = base_url + 'content' + str(page) + '.html'
    print(page_url)
    res = requests.get(url=page_url, headers=headers)

    html = res.text
    soup = BeautifulSoup(html, 'html.parser')
    text = soup.getText(separator='\n', strip=True)
    with open('e:/PycharmProjects/自动化练习/爬取crossin教室的djangogirl的页面内容.txt', 'a+', encoding='utf-8') as file:
        file.write(text)
    print(text)


if __name__ == '__main__':
    for page in range(18):
        pages_parse(page)

二、主要步骤说明:

该示例重点在于通过F12打开使用浏览器开发者工具,F5刷新页面,通过点击XHR过滤出来使用ajax的动态页面,选中页面后,通过右侧的标头选项卡里面的请求URL可以找到有实质页面内容的URL。之后就可以根据URL规律构造每页的URL字符串。然后循环爬取所有的页面。完成抓取。

三、要点说明:

该示例通过BeautifulSoup处理网页源代码中的标签。在码上行动答疑群咨询了Crossin老师,给出了以下的用法。通过调用soup对象的getText()方法,(getText()方法通过指定关键字参数separator='\n'、strip=True实现功能)成功去除了页面源代码中的所有html标签。

text = soup.getText(separator='\n', strip=True)

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-02 19:32:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-02 19:32:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-01-02 19:32:01       87 阅读
  4. Python语言-面向对象

    2024-01-02 19:32:01       96 阅读

热门阅读

  1. 94. 二叉树的中序遍历(“颜色标记法”)

    2024-01-02 19:32:01       53 阅读
  2. 企微群发助手:企业微信营销的得力助手

    2024-01-02 19:32:01       59 阅读
  3. Web网页开发-初识web-笔记

    2024-01-02 19:32:01       58 阅读
  4. 如何使用版本控制工具(如Git)进行代码管理?

    2024-01-02 19:32:01       57 阅读
  5. uni-app、H5+ 下载并保存、打开文件

    2024-01-02 19:32:01       88 阅读
  6. 1303:鸣人的影分身

    2024-01-02 19:32:01       54 阅读
  7. 预编译仓库中的 Helm Chart

    2024-01-02 19:32:01       67 阅读
  8. Bye~ 2023

    2024-01-02 19:32:01       64 阅读
  9. 注解@Slf4j的使用

    2024-01-02 19:32:01       57 阅读
  10. SpringBoot统一标准响应格式及异常处理

    2024-01-02 19:32:01       47 阅读