2

我有一个xml文件,我想解析它以仅获取学生 ID 和学生姓名。

<students>
    <student>
         <id type="integer">101</id>
         <name>James</name>
         <degree>
             <id type="integer">1978271</id>
             <name>SCJP</name>
         </degree>
    </student>
    <student>
         <id type="integer">102</id>
         <name>Joseph</name>
         <degree>
             <id type="integer">1978272</id>
             <name>MCST</name>
         </degree>
    </student>
</students>

代码:

while (eventType != XmlPullParser.END_DOCUMENT) {
    parser.next();
    eventType = parser.getEventType();
    switch (eventType){
    case XmlPullParser.START_TAG:   
         tag_name = parser.getName();
         if(tag_name.equalsIgnoreCase("ID")){
              stud_id = parser.nextText().toString();
              Log.i("Id = ", pid);
          } else if (tag_name.equalsIgnoreCase("name")){
              stud_name = parser.nextText().toString();
          } 
          break;
     }
} 

我的问题:当我XML使用上面的代码解析文件时,我得到了IDs(即student-iddegree-id),所以使用 Pull-parser, 我应该以哪种方式解析XML文件以获取只有 Student-id 的列表

4

1 回答 1

2

当您遇到匹配“student”的起始标签时,将一些布尔变量(例如称为 insideStudent)设置为 true。同样,当您遇到“度”标签时,将另一个 insideDegree 变量设置为 true。当你有一个结束标签时,将它们设置为 false(例如,如果你有,</student>那么你将 insideStudent 设置为 false)。现在,当您遇到 ID 标签时,您只需要检查您是仅在学生内部还是在学位和学生内部。就像是:

if(tag_name.equalsIgnoreCase("ID")){
    // Get student ID
    if (insideStudent && !insideDegree) {
          stud_id = parser.nextText().toString();
          Log.i("Id = ", pid);
    }
} 
于 2010-09-11T13:10:23.417 回答