首页 > 编程语言 >Python爬虫常用框架

Python爬虫常用框架

时间:2023-05-05 10:00:51浏览次数:37  
标签:网页 框架 Python 爬虫 python URL

大家都知道python是一门多岗位编程语言,学习python之后可以从事的岗位有很多,python爬虫便在其中,不过很多人对python不是很了解,所以也不知道python爬虫是什么,接下来小编为大家介绍一下。

Python是一门非常适合开发网络爬虫的编程语言,相比于其他静态编程语言,Python抓取网页文档的接口更简洁;相比于其他动态脚本语言,Python的urllib2包提供了较为完整的访问网页文档的API。此外,python中有优秀的第三方包可以高效实现网页抓取,并可用极短的代码完成网页的标签过滤功能。

爬虫框架是一种用于编写网络爬虫程序的框架,它提供了一些常用的功能,如HTML解析、数据存储、反爬虫策略等,以便开发者能够更快、更高效地开发爬虫程序。

Python爬虫常用框架_爬虫框架

以下是一些常用的爬虫框架:

1、Scrapy:Scrapy是一个基于Python的爬虫框架,它提供了一个基于Twisted的异步网络框架,可以快速地从网站中提取信息。

2、BeautifulSoup:BeautifulSoup是一个Python库,用于从HTML和XML文件中提取信息。它可以从网页中提取出标签、属性和文本,并且可以轻松地处理嵌套结构。

3、PySpider:PySpider是一个轻量级的Python爬虫框架,具有分布式架构和强大的Web UI,可以快速地构建和部署爬虫程序。

4、Requests-HTML:Requests-HTML是一个基于Requests库的Python库,提供了一些用于解析HTML的功能。它可以像Requests一样轻松地发送HTTP请求,并且可以处理JavaScript渲染的网页。

5、Selenium:Selenium是一个用于自动化浏览器的工具,可以模拟用户在浏览器中的操作,如点击、填写表单等。它可以用于处理需要JavaScript渲染的网页,并且可以在多个浏览器中运行。

以上是一些常用的爬虫框架,开发者可以根据自己的需求选择合适的框架进行开发。

Python爬虫架构组成:

1. URL管理器:管理待爬取的url集合和已爬取的url集合,传送待爬取的url给网页下载器;

2. 网页下载器:爬取url对应的网页,存储成字符串,传送给网页解析器;

3. 网页解析器:解析出有价值的数据,存储下来,同时补充url到URL管理器。

Python爬虫工作原理

Python爬虫通过URL管理器,判断是否有待爬URL,如果有待爬URL,通过调度器进行传递给下载器,下载URL内容,并通过调度器传送给解析器,解析URL内容,并将价值数据和新URL列表通过调度器传递给应用程序,并输出价值信息的过程。

Python爬虫常用框架有:

grab:网络爬虫框架;

scrapy:网络爬虫框架,不支持Python3;

pyspider:一个强大的爬虫系统;

cola:一个分布式爬虫框架;

portia:基于Scrapy的可视化爬虫;

restkit:Python的HTTP资源工具包。它可以让你轻松地访问HTTP资源,并围绕它建立的对象。

demiurge:基于PyQuery的爬虫微框架。

python爬虫详细步骤

下面是一个简单的 Python 爬虫的详细步骤:

1、导入所需的库

在 Python 中,使用 urllib 和 requests 库可以实现基本的网络访问和数据爬取功能,因此需要导入这两个库。

import urllib.request
import requests

2、获取网页内容

使用 urllib 或者 requests 库获取网页内容,通常包括以下步骤:

构建请求头部信息,模拟浏览器访问

headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3'}

发送请求并获取网页内容

url = "Example Domain"
response = requests.get(url, headers=headers)
content = response.content

3、解析网页内容

解析网页内容通常使用正则表达式或者 BeautifulSoup 库进行,以获取需要的数据。

使用正则表达式

import re
pattern = re.compile('<div class="title">(.*?)</div>')
result = pattern.findall(content.decode('utf-8'))

使用 BeautifulSoup

from bs4 import BeautifulSoup
soup = BeautifulSoup(content, 'html.parser')
result = soup.find_all('div', class_='title')

4、存储数据

将获取到的数据存储到本地文件或者数据库中。

存储到本地文件

with open('result.txt', 'w', encoding='utf-8') as f:
    for item in result:
        f.write(item + '\n')

存储到数据库

import pymysql
db = pymysql.connect("localhost", "root", "password", "database")
cursor = db.cursor()
sql = "INSERT INTO test(title) VALUES('%s')" % (result[0])
try:
    cursor.execute(sql)
    db.commit()
except:
    db.rollback()
db.close()

以上就是一个简单的 Python 爬虫的详细步骤。当然,在实际操作过程中还需要注意一些细节问题,如数据清洗、反爬虫策略等。

标签:网页,框架,Python,爬虫,python,URL
From: https://blog.51cto.com/u_13488918/6244890

相关文章

  • 极简爬虫通用模板
    网络爬虫的一般步骤如下:1、确定爬取目标:确定需要爬取的数据类型和来源网站。2、制定爬取策略:确定爬取哪些网页、如何爬取和频率等。3、构建爬虫程序:使用编程语言(如Python)实现爬虫程序,通过HTTP请求获取网页内容,并进行解析和处理。4、数据存储:将爬取到的数据存储到数据库或文件......
  • Python_17 OSI模型和HTTP协议
    一、查缺补漏 1.Wireshark抓报文 2.要学习的所有博客: http://testingpai.com/member/haili/articles二、OSI模型 1.物理层 2.数据链路层 3.网络层 4.传输层:TCP(靠谱的传输协议,传输有限) UDP(广播协议会丢包,不是很靠谱,但是可以传输......
  • [Python]-sklearn模块-机器学习Python入门《Python机器学习手册》-05-处理分类数据
    《Python机器学习手册——从数据预处理到深度学习》这本书类似于工具书或者字典,对于python具体代码的调用和使用场景写的很清楚,感觉虽然是工具书,但是对照着做一遍应该可以对机器学习中python常用的这些库有更深入的理解,在应用中也能更为熟练。以下是根据书上的代码进行实操,注释......
  • Python 模块
    原文:Python模块|菜鸟教程(runoob.com)Python模块(Module),是一个Python文件,以.py结尾,包含了Python对象定义和Python语句。模块让你能够有逻辑地组织你的Python代码段。把相关的代码分配到一个模块里能让你的代码更好用,更易懂。模块能定义函数,类和变量,模块里也能包......
  • 超越 PyTorch 和 TensorFlow,这个国产框架有点东西
    By超神经内容概要:都已经有这么多深度学习框架了,为什么还要搞个OneFlow?在机器学习领域,袁进辉看的比90%的人都长远。 关键词:开源  深度学习框架  OneFlow在深度学习领域,PyTorch、TensorFlow等主流框架,毫无疑问占据绝大部分市场份额,就连百度这样级别的公司,也是花费了大量......
  • #yyds干货盘点#python,Lambda
    lambda 关键字用于创建小巧的匿名函数。lambda a, b: a+b 函数返回两个参数的和。Lambda函数可用于任何需要函数对象的地方。在语法上,匿名函数只能是单个表达式。在语义上,它只是常规函数定义的语法糖。与嵌套函数定义一样,lambda函数可以引用包含作用域中的变量:>>>defmake_......
  • python列表怎么克隆
    克隆(或复制)Python列表有几种方法:使用切片操作符[:]list1=[1,2,3,4,5]list2=list1[:]这会创建list1的一个完整副本并将其分配给list2。使用list()函数list1=[1,2,3,4,5]list2=list(list1)这将使用list()函数将list1转换为列表并将其分配......
  • 基于深度学习的水果检测与识别系统(Python界面版,YOLOv5实现)
    摘要:本博文介绍了一种基于深度学习的水果检测与识别系统,使用YOLOv5算法对常见水果进行检测和识别,实现对图片、视频和实时视频中的水果进行准确识别。博文详细阐述了算法原理,同时提供Python实现代码、训练数据集,以及基于PyQt的UI界面。通过YOLOv5实现对图像中存在的多个水果目标......
  • Stata与Python的交互使用
    官方参考文档https://www.stata.com/python/api17/index.html不论是从Stata里调用python,还是从python里调用stata,都无法实现stata和python的数据互通。为了实现stata和Python的数据互通,stata官方提供了名为sfi(StataFunctionInterface)的包,可以在python中获得stata的数据。先......
  • [oeasy]python0048_注释_comment_设置默认编码格式
    注释Comment回忆上次内容使用了版本控制git制作备份进行回滚 尝试了嵌套的控制结构层层控制 不过除非到不得以尽量不要太多层次的嵌套 这样从顶到底含义明确而且还扁平 扁平也能含义明确......