0

我不确定如何格式化 XML 文件,所以如果它在 stackoverflow 代码格式中不可读,这里有一个直接链接。

XML 说明:

测试 = 根
名称 = 测试
numofIndx 的子级 -> 居住 = 名称
索引的子级 = 测试的子级

- <test>
- <name index="2-6">
  <numOfIndx>5</numOfIndx> 
  <freqStart>1.0</freqStart> 
  <freqStop>49.405</freqStop> 
  <numOfPoints>75</numOfPoints> 
  <attenuation>10</attenuation> 
  <dwellms>10</dwellms> 
  </name>
- <index number="2">
  <freqStart>1.0</freqStart> 
  <freqStep>0.1</freqStep> 
  <level>-16</level> 
  <numOfPoints>8</numOfPoints> 
  </index>
+ <index number="3">
  <freqStart>1.8</freqStart> 
  <freqStep>0.1</freqStep> 
  <level>-9</level> 
  <numOfPoints>2</numOfPoints> 
  </index>
+ <index number="4">
  <freqStart>2.0</freqStart> 
  <freqStep>0.1</freqStep> 
  <level>-1</level> 
  <numOfPoints>1</numOfPoints> 
  </index>
+ <index number="5">
  <freqStart>2.1</freqStart> 
  <freqStep>0.1</freqStep> 
  <level>-1</level> 
  <numOfPoints>4</numOfPoints> 
  </index>
+ <index number="6">
  <freqStart>2.5</freqStart> 
  <freqStep>0.795</freqStep> 
  <level>-1</level> 
  <numOfPoints>60</numOfPoints> 
  </index>
- <name index="14-15">
  <numOfIndx>2</numOfIndx> 
  <freqStart>705.45203</freqStart> 
  <freqStop>900</freqStop> 
  <numOfPoints>392</numOfPoints> 
  <attenuation>55</attenuation> 
  <dwellms>10</dwellms> 
  </name>
+ <index number="14">
  <freqStart>705</freqStart> 
  <freqStep>0.5</freqStep> 
  <level>-60</level> 
  <numOfPoints>41</numOfPoints> 
  </index>
+ <index number="15">
  <freqStart>725</freqStart> 
  <freqStep>0.5</freqStep> 
  <level>-50</level> 
  <numOfPoints>351</numOfPoints> 
  </index>
  </test>

我正在尝试将 XML 数据读入一个结构。目前,我从 index="2-6" 读取所有数据没有问题。但是,我似乎无法在第二个循环中导航到 index="14-15" 。我试图调试,但我似乎无法弄清楚为什么我的“前进到下一个兄弟代码”对“索引”兄弟姐妹有效,但不适用于“名称”兄弟姐妹。

当我运行我的代码时,当 getAttr 尝试返回为 NULL 的 pElement 时,第二个循环 (i = 1) 失败。
错误信息:

http://i.imgur.com/s5yT6nC.png

相关代码:主要:

 //Fill test structure loop
    for (int i{ 0 }; i < 2; i++)
        {
            test[i].testName = xml.getAttr("name", "index", i);
            test[i].noi = xml.getInt("name", "numOfIndx", i);
            test[i].freqStart = xml.getFloat("name", "freqStart", i);
            test[i].freqStop = xml.getFloat("name", "freqStop", i);
            test[i].points = xml.getInt("name", "numOfPoints", i);
            test[i].att = xml.getInt("name", "attenuation", i);
            test[i].dwel = xml.getInt("name", "dwellms", i);

            for (int j{ 0 }; j < test[i].noi; j++)
            {
                temp = xml.getAttr("index", "number", j);
                test[i].idx[j].index = atoi(temp);
                test[i].idx[j].freqStart = xml.getFloat("index", "freqStart", j);
                test[i].idx[j].freqStep = xml.getFloat("index", "freqStep", j);
                test[i].idx[j].level = xml.getInt("index", "level", j);
                test[i].idx[j].points = xml.getInt("index", "numOfPoints", j);
            }
        }

xml.getAttr/float/int 本质上都是一样的,所以我只发布getAttr
getAttr:

const char * myXML::getAttr(const char * child, const char * attr, int sibNum)
{
    //Locate root
    XMLNode *pRoot{ findRoot() };
    if (pRoot == nullptr) { return "Error"; }

    XMLElement* pElement{ pRoot->FirstChildElement(child) };
    //If child has identical sibling
    for (int i{ 0 }; i < sibNum; i++)
    {
        //Find that sibling number
        //pElement = nextRel(pElement);
        pElement = pElement->NextSiblingElement();
    }
    if (pElement == nullptr || NULL) { return "Error"; }

    return pElement->Attribute(attr);
}


查找根():

XMLNode * myXML::findRoot()
{
    XMLNode * pRoot{ doc.FirstChild() };
    if (pRoot == nullptr) { return nullptr; }
    return pRoot;
}
4

1 回答 1

0

解决了。它对 i=0 和 i=1 使用相同的根,但是当 i=1 时下一个兄弟元素会改变,因为下一个兄弟元素是“索引”。我将代码更改如下:

const char * myXML::getAttr(const char * child, const char * attr, int sibNum)
    {
        //Locate root
        XMLNode *pRoot{ findRoot() };
        if (pRoot == nullptr) { return "Error"; }

        XMLElement* pElement{ pRoot->FirstChildElement(child) };
        //If child has identical sibling
    for (int i{ 0 }; i < sibNum; i++)
    {
        //Find that sibling number
        //pElement = nextRel(pElement);
        pElement = pElement->NextSiblingElement(child);
    }
    if (pElement == nullptr || NULL) { return "Error"; }

    return pElement->Attribute(attr);
}

这似乎可以解决问题,因为它会查找参数名称 child 的下一个兄弟,而不是自动获取相邻的兄弟。

于 2015-08-13T16:57:42.277 回答