自动化数据处理:使用Selenium与Excel打造的数据爬取管道

news2024/10/19 22:19:19

爬虫代理

随着互联网信息爆炸式增长,获取有效数据成为决策者的重要任务。人工爬取数据不仅耗时且效率低下,因此自动化数据处理成为一种高效解决方案。本文将介绍如何使用Selenium与Excel实现数据爬取与处理,结合代理IP技术构建一个可稳定运行的数据爬取管道,专门用于从WIPO(世界知识产权组织)的Brand Database网站(branddb.wipo.int)中获取专利和技术信息。

一、项目概述

本项目的目标是从WIPO品牌数据库中抓取特定专利和技术信息,并使用Selenium进行自动化操作。为了避免被网站封锁,我们还将引入代理IP服务,例如使用爬虫代理,来提升爬取的稳定性和隐私性。最后,爬取的数据将会存储在Excel文件中,便于后续的数据分析和处理。

二、技术选型与工具简介

  1. Selenium:用于模拟用户操作,自动化执行浏览器行为,尤其适合处理JavaScript动态加载的网页。
  2. Excel (openpyxl库):用于处理数据存储,将爬取到的数据以表格的形式保存,便于后续分析。
  3. 代理IP技术:通过使用代理IP,避免爬取过程中过于频繁的访问而被封禁,提升数据获取的稳定性。本文将使用爬虫代理服务。

三、Selenium的基本设置

首先,我们需要安装并配置Selenium、openpyxl库和代理IP相关的设置。

pip install selenium openpyxl

接着,需要下载合适的浏览器驱动程序(如ChromeDriver)并将其配置到系统路径。

四、使用代理IP技术进行爬取

爬虫时,如果频繁访问某个网站,IP地址容易被封禁。因此,我们可以使用爬虫代理服务,通过代理IP技术隐藏真实的IP地址,从而避免被限制。

代理IP配置示例:
  • 域名: proxy.16yun.cn
  • 端口: 8000
  • 用户名: your_username
  • 密码: your_password

五、Selenium与代理IP结合

我们先来看如何将Selenium与代理IP技术相结合,以便爬取网站。

1. 配置代理IP

在启动浏览器时,通过设置代理IP来实现请求转发。

from selenium import webdriver
from selenium.webdriver.chrome.options import Options

# 设置代理IP的地址和端口 亿牛云爬虫代理 www.16yun.cn
proxy_host = "proxy.16yun.cn"
proxy_port = "8000"
proxy_user = "your_username"
proxy_pass = "your_password"

# 配置代理IP
chrome_options = Options()
chrome_options.add_argument(f"--proxy-server=http://{proxy_user}:{proxy_pass}@{proxy_host}:{proxy_port}")

# 启动浏览器
driver = webdriver.Chrome(options=chrome_options)

通过这种方式,Selenium将通过代理IP访问目标网站,规避IP限制问题。

2. 使用Selenium爬取WIPO Brand Database

接下来,我们实现从WIPO品牌数据库获取数据的核心代码。

import time
from selenium.webdriver.common.by import By

# 打开WIPO品牌数据库
driver.get("https://branddb.wipo.int")

# 等待页面加载
time.sleep(5)

# 查找专利技术信息的输入框并输入关键字
search_box = driver.find_element(By.ID, "searchInput")
search_box.send_keys("technology patent")  # 输入搜索关键词

# 点击搜索按钮
search_button = driver.find_element(By.CLASS_NAME, "searchButton")
search_button.click()

# 等待结果加载
time.sleep(10)

# 抓取结果页面的专利信息
results = driver.find_elements(By.CLASS_NAME, "result-item")

# 遍历结果并提取相关信息
patent_data = []
for result in results:
    title = result.find_element(By.CLASS_NAME, "title").text
    description = result.find_element(By.CLASS_NAME, "description").text
    patent_data.append((title, description))

# 关闭浏览器
driver.quit()

六、将爬取的数据存储到Excel

使用Python的openpyxl库将爬取的数据存储到Excel文件中,便于后续的分析和处理。

from openpyxl import Workbook

# 创建Excel工作簿
wb = Workbook()
ws = wb.active

# 写入表头
ws.append(["Title", "Description"])

# 写入爬取的数据
for title, description in patent_data:
    ws.append([title, description])

# 保存Excel文件
wb.save("WIPO_patent_data.xlsx")

通过这个代码段,我们将抓取到的专利和技术信息保存到Excel文件WIPO_patent_data.xlsx中,方便后续分析。

七、代理IP的重要性与使用技巧

在网络爬虫中,使用代理IP是一种常见的规避反爬虫机制的方法。选择合适的代理服务商(如亿牛云爬虫代理)非常重要。以下是使用代理IP时的一些注意事项:

  1. 稳定性:选择拥有高质量IP池的代理商,确保爬虫能持续运行。
  2. 并发量:检查代理IP服务商允许的并发量,确保能满足大规模爬取的需求。
  3. 切换频率:合理设置代理IP切换频率,避免使用同一个IP爬取大量数据。

八、总结

本文介绍了如何使用Selenium与代理IP技术相结合,构建一个稳定高效的数据爬取管道。通过Selenium实现自动化操作,配合代理IP提高爬虫的稳定性,并将爬取到的数据通过openpyxl存储到Excel中,形成完整的数据处理流程。

这套方法不仅适用于WIPO品牌数据库,其他类似的网站也可以用类似的方式进行自动化数据爬取与处理。通过这种方式,用户可以轻松地获取大量的专利与技术信息,并为后续的决策提供有力的数据支撑。

九、未来展望

随着数据量的增长和网站的反爬虫技术的升级,代理IP技术的灵活运用将显得更加重要。未来,可以考虑引入更多的防反爬策略,如设置请求间隔、使用无头浏览器等,以进一步提升爬虫的效率和稳定性。

通过合理的自动化爬取方案,数据获取将变得更加高效和智能,为决策提供更加准确的数据支持。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2218788.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Nodejs使用http模块创建Web服务器接收解析RFID读卡器刷卡数据

本示例使用设备: https://item.taobao.com/item.htm?spma21dvs.23580594.0.0.1d292c1buHvw58&ftt&id22173428704 Javascript源码 //引用http模块创建web服务器,监听指定的端口获取以GET、POST、JSON等方式上传的数据,并回应驱动读卡…

图像梯度-Sobel算子、scharrx算子和lapkacian算子

文章目录 一、认识什么是图像梯度和Sobel算子二、Sobel算子的具体使用三、scharrx算子与lapkacian(拉普拉斯)算子 一、认识什么是图像梯度和Sobel算子 图像的梯度是指图像亮度变化的空间导数,它描述了图像在不同方向上的强度变化。在图像处理和计算机视觉中&#x…

CUDA error: out of memory问题

加载模型时,模型也不大,GPU内存也完全够,但就是出现这个CUDA内存溢出问题。 究其原因,在于model.load_state_dict(torch.load(‘pretrain-model.pth’, map_locationdevice))这个代码省略了map_locationdevice 通过torch.load加载…

YOLOv11来了 | 自定义目标检测

概述 YOLO11 在 2024 年 9 月 27 日的 YOLO Vision 2024 活动中宣布:https://www.youtube.com/watch?vrfI5vOo3-_A。 YOLO11 是 Ultralytics YOLO 系列的最新版本,结合了尖端的准确性、速度和效率,用于目标检测、分割、分类、定向边界框和…

问题清除指南|alimama-creative/FLUX-Controlnet-Inpainting 运行注意事项

前言:近日验证想法需要用到inpainting技术,选择了https://github.com/alimama-creative/FLUX-Controlnet-Inpainting进行测试,在实现过程中遇到几个小问题,在此分享一下解决经验。 1. 下载预训练模型到本地 由于在huggingface官网…

React Agent 自定义实现

目录 背景 langchin 中的 agent langchin 中 agent 的问题 langchain 的 agent 案例 自定义 React Agent 大模型 工具定义 问题设定 问题改写,挖掘潜在意图 React Prompt 下一步规划 问题总结 代码 背景 之前使用过 langchian 中的 agent 去实现过一些…

WordPress监控用户行为回放插件

在数字营销的世界里,了解用户行为是提升用户体验和转化率的关键。nicen-replay 插件,它能够让您轻松回放用户在网站上的每一步操作,从点击到滚动,再到表单填写,每一个细节都清晰可见 nicen-replay,是一款可…

C#从零开始学习(类型和引用)(4)

类型 本章所有的代码都放在 https://github.com/hikinazimi/head-first-Csharp 整型 byte: 0~255sbyte: -128~127short: -32768~32767int: -2147483648~2147483647long: -9223372036854775808~9223372036854775807 以u开头的无符号整数 ushort,uint,ulong 浮点 float: (6~9…

RHCE【远程连接服务器】

目录 一、远程连接服务器简介 二、加密技术简介 SSH工作过程: (1)版本协商阶段 (2)密钥和算法协商阶段 (3)认证阶段 (4)会话请求阶段 (5&#xff0…

KUKA外部自动配置(上)

通过外部PLC对机器人自动运行进程进行控制,其控制原理是:外部PLC通过外部自动运行接口向机器人控制系统发出机器人进程的相关信号(如:运行许可、故障确认、程序启动等),机器人控制系统向外部PLC系统发送有关…

STM32 I2C通信协议详解

文章目录 STM32 I2C通信协议详解一、I2C协议概述二、物理层特性总线结构:引脚定义:电平特性:地址机制: 三、协议层机制起始信号:停止信号:数据有效性:应答信号(ACK)&…

机器学习|Pytorch实现天气预测

机器学习|Pytorch实现天气预测 🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 电脑系统:Windows11 显卡型号:NVIDIA Quadro P620 语言环境:python 3.9.7 编译器&#x…

【Python】selenium遇到“InvalidArgumentException”的解决方法

在使用try……except 的时候捕获到这个错误: InvalidArgumentException: invalid argument (Session info: chrome112.0.5614.0) 这个错误代表的是,当传入的参数不符合期望时,就会抛出这个异常: InvalidArgumentException: invali…

常见TCP/IP协议基础——计算机网络

目录 前言常见协议基础常见协议-基于TCP的应用层协议常见协议-基于UDP的应用层协议常见协议-网络层协议习题自测1.邮件发送协议2.接收邮件协议端口3.建立连接4.层次对应关系5.FTP服务器端口 前言 本笔记为备考软件设计师时的重点知识点笔记,关于常见TCP/IP协议基础…

Java【多线程】wait和notify

目录 wait / notify 由于线程之间是抢占式执⾏的, 因此线程之间执⾏的先后顺序难以预知. 但是实际开发中有时候我们希望合理的协调多个线程之间的执⾏先后顺序. wait / notify 等待/通知 协调线程之间的执行逻辑的顺序的 可以让后执行的逻辑等待先执行的逻辑 虽然无法直接…

缓存框架JetCache源码解析-缓存定时刷新

作为一个缓存框架,JetCache支持多级缓存,也就是本地缓存和远程缓存,但是不管是使用着两者中的哪一个或者两者都进行使用,缓存的实时性一直都是我们需要考虑的问题,通常我们为了尽可能地保证缓存的实时性,都…

word取消自动单词首字母大写

情况说明:在word输入单词后首字母会自动变成大写 (1)点击菜单栏文件 (2)点击“更多”——>“选项” (3)点击“校对”——>“自动更正选项” (4)取消“句首字母大写…

WPF样式详解:行内样式、模板样式和页面样式的全方位分析

Windows Presentation Foundation (WPF) 是微软推出的一种用于构建桌面应用程序的UI框架。WPF 提供了强大的样式和模板机制,允许开发人员以声明的方式定义和复用UI元素的视觉外观。本文将深入探讨WPF的行内样式、模板样式和页面样式,帮助您在实际开发中更…

大数据linux操作系统

第一关:Linux的初体验 答案: cd / ls -a / (里面有空格要注意) 第二关:Linux的常用命令 答案: touch newfile mkdir newdir cp newfile newdir/newfileCpy 第三关:Linux查询命令帮助语句…

我在自动化测试方面犯过的3个大错误

每个人都会犯错误,但不管错误看起来有多糟糕,你都可以恢复过来,更重要的是,从错误中学习。 在软件开发过程的任何领域,从编码到测试,我们都会时不时地犯一些错误。通常,这些错误都很小&#xf…