TinyXML2推进到下一个兄弟

时间:2015-08-13 15:43:29

标签: c++ xml tinyxml2

我不确定如何格式化XML文件,因此here是一个直接链接,如果它在stackoverflow代码格式中是不可读的。

XML说明:

test = root
name =测试的孩子
numofIndx - > dwellms =名字的子孙 index =测试的孩子

- <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”。我试图调试,但我似乎无法弄清楚为什么我的“前进到下一个兄弟代码”对于“索引”兄弟姐妹正常工作,而不是“名字”兄弟姐妹。

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

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);
}


findRoot():

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

1 个答案:

答案 0 :(得分:0)

解决。它对i = 0和i = 1使用相同的根,但是当i = 1时,下一个兄弟元素会改变,因为下一个兄弟是&#34; index&#34;。我改变了代码如下:

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的下一个兄弟,而不是仅仅自动获取相邻的兄弟。