C# 将xml拆分为文件-方法占用更少的内存

C# 将xml拆分为文件-方法占用更少的内存,c#,xml,xmlreader,xelement,C#,Xml,Xmlreader,Xelement,我需要将我的XML拆分为文件。 这是我的示例XML的结构: <Data Code="L6POS1"> <Lots RowVersion="464775"> <Lot Id="5" Quantity="10068.0000" GUID="AA616D3D-F442-6AEE-0BAB-1D13F6961C2A" /> <Lot Id="99" Quantity="0.0000" GUID="24A9C957-EC98-85D5-8F96-0

我需要将我的
XML
拆分为文件。 这是我的示例
XML
的结构:

<Data Code="L6POS1">
<Lots RowVersion="464775">
   <Lot Id="5"  Quantity="10068.0000" GUID="AA616D3D-F442-6AEE-0BAB-1D13F6961C2A" />
   <Lot Id="99"  Quantity="0.0000" GUID="24A9C957-EC98-85D5-8F96-0120F6E8A572" />
   <Lot Id="101"  Quantity="0.0000" GUID="124D17A2-1568-DB02-4327-4669FE00F741" />
   <Lot Id="103"  Quantity="0.0000" GUID="DD1730FF-27CF-1269-7AC2-3152CB6FDC46" />
   <Lot Id="105"  Quantity="0.0000" GUID="1F25378F-30D4-E4E0-9939-1E9E69C806C1" />
   <Lot Id="188"  Quantity="0.0000" GUID="2E860029-29B3-54C2-B8D1-0C6ABDA42DFF" />
   <Lot Id="189"  Quantity="0.0000" GUID="D3C58850-BC23-E8DE-A919-09CCB3F8A1D3" />
</Lots>
第二个文件

 <Data Code="L6POS1">
 <Lots RowVersion="464775">
   <Lot Id="5"  Quantity="10068.0000" GUID="AA616D3D-F442-6AEE-0BAB-1D13F6961C2A" />
   <Lot Id="99"  Quantity="0.0000" GUID="24A9C957-EC98-85D5-8F96-0120F6E8A572" />
   <Lot Id="101"  Quantity="0.0000" GUID="124D17A2-1568-DB02-4327-4669FE00F741" />
   <Lot Id="103"  Quantity="0.0000" GUID="DD1730FF-27CF-1269-7AC2-3152CB6FDC46" />   
</Lots>
</Data>
<Data Code="L6POS1">
 <Lots RowVersion="464775">
   <Lot Id="105"  Quantity="0.0000" GUID="1F25378F-30D4-E4E0-9939-1E9E69C806C1" />
   <Lot Id="188"  Quantity="0.0000" GUID="2E860029-29B3-54C2-B8D1-0C6ABDA42DFF" />
   <Lot Id="189"  Quantity="0.0000" GUID="D3C58850-BC23-E8DE-A919-09CCB3F8A1D3" />
</Lots>
</Data>

实际上,我正在使用:

   private IEnumerable<XElement> CreateXMLPackagesByType(string syncEntityName, XElement root)
    {
        var xmlList = new List<XElement>();
        IEnumerable<XElement> childNodes = root.Elements();

        var childsCount = childNodes.Count();

        var skip = 0;
        var take = ConfigurationService.MaxImportPackageSize;
        var rootAttributes = root.Attributes();
        XElement rootWithoutDescendants;
        while (skip < childsCount)
        {
            rootWithoutDescendants = new XElement(root.Name);
            rootWithoutDescendants.Add(rootAttributes);

            var elems = childNodes.Skip(skip).Take(take);
            skip += take;
            xmlList.Add(CreatePackage(rootWithoutDescendants, elems));
        }

        return xmlList;
    }


      private XElement CreatePackage(XElement type, IEnumerable<XElement> elems)
    {
        type.Add(elems);
        var root = new XElement("Data", type);
        root.Add(new XAttribute("Code", ConfigurationService.Code));
        return root;
    }
private IEnumerable CreateXMLPackagesByType(字符串syncEntityName,XElement根)
{
var xmlList=新列表();
IEnumerable childNodes=root.Elements();
var childscont=childNodes.Count();
var-skip=0;
var take=ConfigurationService.MaxImportPackageSize;
var rootAttributes=root.Attributes();
没有后代的根;
while(跳过

不幸的是,通过这种方式,在旧硬件上使用更大的
XML
文件会出现get
OutOfMemoryException
。拆分
XElement
是更好的方法吗

前面建议使用SAX解析器的评论是正确的——这样一来,您一次只获取一个事件(元素等),之后就不必保留任何内容


如果您完全确定您的数据像您的示例一样整齐地分成了几行,那么一个快速而肮脏的方法就是不进行解析,而是一次只读取一行。先处理前两个,然后按照你的意愿分解其余的,然后处理最后两个。但要确保(换句话说,检查)每个
元素只占用一条物理线;正如您可能已经知道的那样,在XML中通常没有理由这样做。

考虑而不是?您需要使用SAX解析器而不是文档解析器。正如@Tom指出的,XmlReader是一个不错的选择。您也可以将其编译为64位—这不是最好的解决方案—只需说:-)