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
文件会出现getOutOfMemoryException
。拆分XElement
是更好的方法吗 前面建议使用SAX解析器的评论是正确的——这样一来,您一次只获取一个事件(元素等),之后就不必保留任何内容
如果您完全确定您的数据像您的示例一样整齐地分成了几行,那么一个快速而肮脏的方法就是不进行解析,而是一次只读取一行。先处理前两个,然后按照你的意愿分解其余的,然后处理最后两个。但要确保(换句话说,检查)每个
元素只占用一条物理线;正如您可能已经知道的那样,在XML中通常没有理由这样做。考虑而不是?您需要使用SAX解析器而不是文档解析器。正如@Tom指出的,XmlReader是一个不错的选择。您也可以将其编译为64位—这不是最好的解决方案—只需说:-)