Nokogiri是Ruby中解析XML最常用且功能强大的库,支持从字符串或文件加载XML,通过CSS选择器或XPath查询节点,获取属性和文本内容,并处理解析错误,使用简单且性能良好。

Ruby 中解析 XML 最常用且功能强大的库是 Nokogiri。它支持 XML 和 HTML 的解析、搜索和修改,使用简单且性能良好。下面带你快速入门 Nokogiri 如何解析 XML。
gem install nokogiri
gem 'nokogiri'
bundle install。
xml_content = <<-XML<br>
<books><br>
<book id="1"><br>
<title>Ruby 入门指南</title><br>
<author>张三</author><br>
</book><br>
<book id="2"><br>
<title>Rails 实战</title><br>
<author>李四</author><br>
</book><br>
</books><br>
XML
require 'nokogiri'<br><br>
doc = Nokogiri::XML(xml_content)<br>
# 确保没有解析错误<br>
puts doc.errors unless doc.errors.empty?
CSS 选择器示例:
# 获取所有 book 节点<br>
books = doc.css('book')<br>
books.each do |book|<br>
puts "ID: #{book['id']}"<br>
puts "标题: #{book.at_css('title').content}"<br>
puts "作者: #{book.at_css('author').content}"<br>
end
XPath 示例:
Python v2.4版chm格式的中文手册,内容丰富全面,不但是一本手册,你完全可以把她作为一本Python的入门教程,教你如何使用Python解释器、流程控制、数据结构、模板、输入和输出、错误和异常、类和标准库详解等方面的知识技巧。同时后附的手册可以方便你的查询。
2
# 使用 XPath 获取所有 book/title 文本<br>
titles = doc.xpath('//book/title/text()')<br>
titles.each { |title| puts title.to_s }
注意:css 返回节点集合,at_css 或 at_xpath 返回第一个匹配节点。
text 方法。
book = doc.at('book')<br>
id = book['id'] # 获取 id 属性值<br>
title_text = book.at('title').text # 获取 title 的文本
也可以判断节点是否存在:
if book.at('title')<br>
puts "标题存在:#{book.at('title').text}"<br>
else<br>
puts "标题缺失"<br>
end
基本上就这些。Nokogiri 上手快,语法清晰,是 Ruby 处理 XML 的首选工具。只要会写 CSS 或 XPath,就能高效提取所需数据。
以上就是Ruby如何解析xml? Nokogiri库使用入门的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号