0

我尝试使用 XmlPullParser 解析简单的 xml 文件。

<?xml version="1.0" encoding="utf-8"?>

<tests>
    <test>
        <name>Jack</name>
    </test>
    <test>
        <name>Brad</name>
    </test>
    <test>
        <name>Tom</name>
    </test>
</tests>

这是 MainActivity 代码:

public class MainActivity extends ActionBarActivity {
    ViewPager viewPager;
    PagerAdapter pagerAdapter;
    ArrayList<Quote> quotes;
    ArrayList<Pers> persons;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        InputStream inputStream = getResources().openRawResource(R.xml.test);

        Fetcher fetcher = new Fetcher();
        persons = fetcher.parse(inputStream);

        String str = new String();
        for(int i = 0; i < persons.size(); i++) {
            str += persons.get(i).getName();
        }
        Log.d("1", str);
    }
}

这是 Fetcher 类代码:

public class Fetcher {
    private ArrayList<Pers> persons;
    private Pers person;
    private String text;

    public Fetcher() {
        persons = new ArrayList<Pers>();
    }

    public ArrayList<Pers> parse(InputStream is) {
        XmlPullParserFactory factory = null;
        XmlPullParser parser = null;
        try {
            factory = XmlPullParserFactory.newInstance();
            factory.setNamespaceAware(true);
            parser = factory.newPullParser();
            parser.setInput(is, null);
            int eventType = parser.getEventType();
            while(eventType != XmlPullParser.END_DOCUMENT) {
                String tagname = parser.getName();
                switch(eventType) {
                    case XmlPullParser.START_TAG:
                        if(tagname.equalsIgnoreCase("test")) {
                            person = new Pers();
                        }
                        break;
                    case XmlPullParser.TEXT:
                        text = parser.getText();
                        break;
                    case XmlPullParser.END_TAG:
                        if(tagname.equalsIgnoreCase("test")) {
                            persons.add(person);
                        } else if(tagname.equalsIgnoreCase("name")) {
                            person.setName(text);
                        }
                        break;
                    default:
                        break;
                }
                eventType = parser.next();
            }
        } catch(XmlPullParserException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return persons;
    }
}

为什么会出现 XmlPullParserException 异常?

org.xmlpull.v1.XmlPullParserException: unterminated entity ref (position:TEXT ��������������������...@1:49 in java.io.InputStreamReader@405534d8)
4

4 回答 4

2

我更改了代码,现在它可以工作了。感谢那些试图帮助我的人。

public class Fetcher {
    private ArrayList<Pers> persons;
    private Pers person;
    private String text;

    public Fetcher() {
        persons = new ArrayList<Pers>();
    }

    public ArrayList<Quote> parse(Activity activity) throws XmlPullParserException, IOException {
        Resources resources = activity.getResources();
        XmlResourceParser xmlResourceParser = resources.getXml(R.xml.quotes);
        person = new Pers();
        xmlResourceParser.next();
        int eventType = xmlResourceParser.getEventType();
        while(eventType != XmlPullParser.END_DOCUMENT) {
            String tagName = xmlResourceParser.getName();
            switch(eventType) {
                case XmlPullParser.START_TAG: {
                    if(tagName.equalsIgnoreCase("test")) {
                        person = new Pers();
                    }
                    break;
                }

                case XmlPullParser.TEXT: {
                    text = xmlResourceParser.getText();
                    break;
                }

                case XmlPullParser.END_TAG: {
                    if(tagName.equalsIgnoreCase("test")) {
                        persons.add(person);
                    } else if(tagName.equalsIgnoreCase("name")) {
                        person.setId(Integer.parseInt(text));
                    }
                    break;
                }

                default:
                    break;
            }
            eventType = xmlResourceParser.next();
        }

        return persons;
    }
}
于 2013-10-21T19:09:29.933 回答
0

我想是这条线:parser.setInput(is, null);

因为xml编码是UTF-8,相信你得改成parser.setInput(is,"UTF-8");

于 2013-10-21T17:55:41.527 回答
0

我认为问题在于您向我们展示的内容不同。或者源代码可能不同。

  • 错误消息似乎引用了一个不存在的位置 - 第 1 行,字符位置 49(反之亦然)。

  • 错误消息似乎表明一些乱码字符(或 NUL 字符串),但在示例 XML 中没有任何问题。

于 2013-10-21T18:18:21.843 回答
0

有点晚了,但如果它对其他人有帮助,请检查:

  • XML 文件中没有需要转义的字符,例如 & 应该是 &#amp;
  • 确保属性正确地括在引号中(在我的情况下,eclipse 有助于将右引号放入,所以当我在文本末尾添加右引号时,它给出了一个错误

我从最外面的标签开始检查我的 XML,删除内容并重新添加位,每次运行,以查找错误所在。调试 XML 文件真的很痛苦!

于 2015-03-23T09:17:02.717 回答