需要关于调试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数据是干净的。有人知道为什么当样本数量增加时,时间会非线性增加吗?或者问题出在其他地方?

谢谢!

需要关于调试c#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; }
}