为了简单起见,我将大大降低我的项目的复杂性,并给出一个简单但同样准确的例子来说明我正在努力解决的问题。我有两个 XML 文件,我们将它们命名Read.xml
为Write.xml
. 目标是让我的项目读取Read.xml的内容,将 XML 解析为一个类,然后将其重建为Write.xml。
XML 生成到Read.xml中的方式是,当元素没有值时,它使用速记结束标记 ( <ElementName />
),而当它确实有值时,它使用速记结束标记 ( <ElementName>Element Value</ElementName>
)。我无法控制Read.xml中 XML 的生成。
下面的代码非常适合解析 XML,只要它使用普通结束标记。但是,如果 ReportId
下面说要使用速记结束标记,那么现在的代码将读取下一行(对于长手写结束标记将是 XML 元素的值),但下一行是一个空格值为"\n"的元素。然后,这会在Write.xml中的 XML 中添加一个新行, 这会使 XML 格式变得奇怪。这是我用来从Read.xml读取和解析 XML 的代码:
while(xmlReader.Read())
{
switch(xmlReader.NodeType)
{
case XmlNodeType.Element:
if(xmlReader.Name.Equals("ReportSummary") && xmlReader.IsStartElement())
{
currentReport = new Entities.Report();
}
else if(xmlReader.Name.Equals("ReportName"))
{
xmlReader.Read();
currentReport.ReportName = xmlReader.Value;
}
else if(xmlReader.Name.Equals("ReportId"))
{
xmlReader.Read();
currentReport.ReportId = xmlReader.Value;
}
break;
case XmlNodeType.EndElement: //Reached the end of the element.
if(xmlReader.Name.Equals("ReportSummary"))
{
if(currentReport!= null)
{
reportList.Add(currentReport);
currentReport = null;
}
}
break;
default:
break;
}
}
我的问题是,是否有适当的方法来处理速记结束标签与长手结束标签。或者,有没有更好的方法来解析一个 XML 文件?
提前感谢大家提供的任何东西。