我需要使用 .net 文件读取大型 xml,这些文件的大小很容易达到几 GB.
I need to read large xml using .net files which can easily be several GB of size.
我尝试使用 XDocument,但是当我尝试加载文档时它只是抛出 System.OutOfMemoryException.
I tried to use XDocument, but it just throws an System.OutOfMemoryException when I try to load the document.
读取大尺寸 XML 文件的最佳方式是什么?
What is the most performant way to read XML files of large size?
你基本上有在这里使用拉"模型 - XmlReader 和朋友.这将允许您流式传输文档,而不是一次性将其全部加载到内存中.
You basically have to use the "pull" model here - XmlReader and friends. That will allow you to stream the document rather than loading it all into memory in one go.
请注意,如果您知道自己处于足够小"元素的开头,则可以创建一个 XElement 来自 XmlReader,使用 LINQ to XML 的荣耀处理它,然后移动到下一个元素.
Note that if you know that you're at the start of a "small enough" element, you can create an XElement from an XmlReader, deal with that using the glory of LINQ to XML, and then move onto the next element.
这篇关于在 .net 中读取大型 XML 文档的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
读取 XML 时忽略空格Ignore whitespace while reading XML(读取 XML 时忽略空格)
带有检查空元素的 XML 到 LINQXML to LINQ with Checking Null Elements(带有检查空元素的 XML 到 LINQ)
在 C# 中读取带有未闭合标签的 XMLReading XML with unclosed tags in C#(在 C# 中读取带有未闭合标签的 XML)
在 C# 中使用 Html 敏捷性解析表格、单元格Parsing tables, cells with Html agility in C#(在 C# 中使用 Html 敏捷性解析表格、单元格)
使用 LINQ 从 xml 中删除元素delete element from xml using LINQ(使用 LINQ 从 xml 中删除元素)
解析格式错误的 XMLParse malformed XML(解析格式错误的 XML)