需要关于调试c#XML解析的帮助
本文关键字:c#XML 帮助 调试 于调试 | 更新日期: 2023-09-27 18:00:36
我的c#代码使VisualStudio(2013)在使用整个XML文件(189个描述符,每个描述符有64个特性)时没有响应,但在少量情况下效果良好
Matrix<float> ObjectDescriptors = new Matrix<float>(200, 64);
XmlTextReader reader = new XmlTextReader("descriptors.xml");
int i = -1;
int ii = 0;
while (reader.Read())
{
if (reader.Name == "feature" && ii < 64)
{
ObjectDescriptors[i, ii] = reader.ReadElementContentAsFloat();
ii++;
if (ii == 64) ii = 0;
}
else if (reader.Name == "descriptor") i++;
}
XML数据是干净的。有人知道为什么当样本数量增加时,时间会非线性增加吗?或者问题出在其他地方?
谢谢!
您有任何异常处理吗?
表达式:else if (reader.Name == "descriptor") i++;
必须导致i
的增量以及开始元素descriptor
,作为结束元素。
在我的测试代码中,这导致IndexOutOfRangeException。也许您的代码挂起了异常处理?
试试这个:else if (reader.NodeType == XmlNodeType.Element && reader.Name == "descriptor") i++;
此外,我还可以提供两种方式。
使用NameTable。这可能会提高性能。然而,节点189*64的数量不是很大。这种差异几乎可以忽略不计。
NameTable nt = new NameTable();
object feature = nt.Add("feature");
object descriptor = nt.Add("descriptor");
var settings = new XmlReaderSettings();
settings.NameTable = nt;
using (var reader = XmlReader.Create("descriptors.xml", settings))
{
int i = -1;
int ii = 0;
while (reader.Read())
{
if (object.ReferenceEquals(feature, reader.Name))
{
ObjectDescriptors[i, ii] = reader.ReadElementContentAsFloat();
ii++;
if (ii == 64) ii = 0;
}
else if (reader.NodeType == XmlNodeType.Element && object.ReferenceEquals(descriptor, reader.Name)) i++;
}
}
另一种方式:
using (var reader = XmlReader.Create("descriptors.xml"))
{
while (reader.Read())
{
if (reader.ReadToFollowing("descriptor"))
{
int i = -1;
do
{
i++;
if (reader.ReadToFollowing("feature"))
{
int ii = 0;
do
{
ObjectDescriptors[i, ii] = reader.ReadElementContentAsFloat();
ii++;
} while (reader.ReadToNextSibling("feature"));
}
} while (reader.ReadToNextSibling("descriptor"));
}
}
}
我从-1开始使用了你丑陋的索引。
还要注意,XmlTextReader在很久以前就不推荐使用了。使用XmlReader.Create.创建读取器
PS:?при刺绣。
如果是XML解析器,您可以尝试其他方法,如
float[,] data = new Float[200,64];
int row = 0, col = 0;
var tags = XElement.Parse(file).XPathSelectElements("descriptor|feature");
foreach(var node in tags)
{
if (node.Name == "descriptor")
{ row++; col = 0; }
else if (node.Name == "feature")
{ data[row, col++] = (float)node; }
}