使用 Ruby 的 Nokogiri 库来解析

爬虫程序的主要目标是获取指定网站上的数据。在这里,我们将使用 Ruby 的 Nokogiri 库来解析 HTML,并使用 HTTParty 库来发送 HTTP 请求。下面是一个简单的示例,演示如何使用 Ruby 编写一个爬虫程序来爬取 1688 网站的数据。

ruby 复制代码
require 'nokogiri'
require 'httparty'


# 定义要爬取的 URL
url = "jshk.com.cn"

# 使用 HTTParty 发送 HTTP 请求
response = HTTParty.get(url, headers: { "Proxy-Host" => proxy_host, "Proxy-Port" => proxy_port })

# 使用 Nokogiri 解析 HTML
doc = Nokogiri::HTML(response.body)

# 获取网页中的所有商品链接
links = doc.css(".product-item")

links.each do |link|
  puts link["href"]
end

上述代码的工作步骤如下:

  1. 首先,我们引入了 Nokogiri 和 HTTParty 库。

  2. 然后,我们设置了代理信息,包括代理服务器的主机名和端口号。

  3. 接下来,我们定义了要爬取的 URL,即 1688 网站的首页。

  4. 使用 HTTParty 发送 HTTP 请求,并设置代理信息。

  5. 使用 Nokogiri 解析返回的 HTML。

  6. 使用 CSS 选择器获取网页中的所有商品链接。

  7. 最后,遍历所有链接,并打印出每个链接的 URL。

注意:在实际使用中,可能需要处理各种异常情况,例如网络连接错误、HTTP 请求错误等。

相关推荐
爱学习的小可爱卢19 小时前
JavaEE进阶——Spring Bean与Java Bean的核心区别
java·后端·java-ee
我是人机不吃鸭梨19 小时前
Flutter AI 集成革命(2025版):从 Gemini 模型到智能表单验证器的终极方案
开发语言·javascript·人工智能·flutter·microsoft·架构
沐知全栈开发19 小时前
服务定位器模式
开发语言
37手游后端团队19 小时前
Cursor 工作区使用技巧:让 AI 真正理解你的多项目协作
后端·面试·架构
期待のcode19 小时前
Java Object 类
java·开发语言
武子康19 小时前
大数据-198 KNN 必须先归一化:Min-Max 正确姿势、数据泄露陷阱与 sklearn 落地
大数据·后端·机器学习
Wang's Blog19 小时前
Lua: 协程编程详解之从基础到多任务处理与应用实战
开发语言·lua
笙枫19 小时前
LangGraph Agent 架构基础:从概念到第一个可运行的Agent
开发语言·架构·php
李拾叁的摸鱼日常19 小时前
Java Optional 最佳实践+注意事项+避坑指南
java·后端·面试
啊哈灵机一动19 小时前
手把手实现 Gin + Socket.IO 实时聊天功能
后端