Я проанализировал XML-файл, но мне нужно еще разбить строку внутри него, как мне это сделать? - PullRequest
0 голосов
/ 14 апреля 2019

Я проанализировал фид XML, но внутри одного из тегов я хочу дополнительно проанализировать данные, но не уверен, как это сделать? Я использую XMLPullParser для этого в пакете, затем информация сохраняется в пакете Widgetclass, а затем отправляется в мою основную деятельность через намерение с использованием широковещательного приемника.

в настоящее время код вызывает только одно поле анализируемой информации, но вызов more представляет проблему содержимого несортированного тега XML. Кажется, я не могу заставить метод split.String работать здесь, должен ли он быть в классе виджетов, который я должен хранить, или в mainacctivity?

// парсер public static WidgetClass [] parseFeed (содержимое строки) {

    try {

        boolean inItemTag = false;
        String currentTagName = "";
        WidgetClass currentItem = null;
        List<WidgetClass> itemList = new ArrayList<>();

        XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
        XmlPullParser parser = factory.newPullParser();
        parser.setInput(new StringReader(content));

        int eventType = parser.getEventType();

        while (eventType != XmlPullParser.END_DOCUMENT) {

            switch (eventType) {
                case XmlPullParser.START_TAG:
                    currentTagName = parser.getName();
                    if (currentTagName.equals("item")) {
                        inItemTag = true;
                        currentItem = new WidgetClass();
                        itemList.add(currentItem);
                    }
                    break;

                case XmlPullParser.END_TAG:
                    if (parser.getName().equals("item")) {
                        inItemTag = false;
                    }
                    currentTagName = "";
                    break;

                case XmlPullParser.TEXT:
                    String text = parser.getText();
                    if (inItemTag && currentItem != null) {
                        try {
                            switch (currentTagName) {
                                case "title":
                                    currentItem.setTitle(text);
                                    break;
                                case "description":
                                    currentItem.setDescription(text);
                                    break;
                                case "link":
                                    currentItem.setLink(text);
                                    break;
                                case "pubDate":
                                    currentItem.setPubDate(text);
                                    break;
                                case "category":
                                    currentItem.setCatagory(text);
                                    break;
                                case "geo:lat":
                                    currentItem.setGeoLat(Double.parseDouble(text));
                                case "geo:long":
                                    currentItem.setGeoLong(Double.parseDouble(text));
                                default:
                                    break;
                            }
                        } catch (NumberFormatException e) {
                            e.printStackTrace();
                        }
                    }
                    break;
            }

            eventType = parser.next();

        } // end while loop


       WidgetClass[] widgetClasses = new WidgetClass[itemList.size()];
        return itemList.toArray(widgetClasses);

    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }

В идеале я хотел бы дополнительно отделить поток от тега, а затем поместить их в массив для передачи на мой визуальный уровень.

1 Ответ

0 голосов
/ 15 апреля 2019

Ваш пример строки:

<description> Origin date/time: Thu, 14 Feb 2019 07:43:33 ; Location: NEWDIGATE,SURREY ; Lat/long: 51.163,-0.250 ; Depth: 2 km ; Magnitude: 2.4 </description> 

Как видите, все части строк разделены знаком ';'.В этом случае вы можете использовать этот символ для разделения строки:

String[] textParts = text.split(";");

Затем каждая часть содержит требуемую часть строки

partsCounts = textParts.length; // number of parts
textParts[0] => " Origin date/time: Thu, 14 Feb 2019 07:43:33 "
textParts[1] => " Location: NEWDIGATE,SURREY "
textParts[2] => "  Lat/long: 51.163,-0.250 "
textParts[3] => " Depth: 2 km "
testParts[4] => "  Magnitude: 2.4 "

Если вы редактируете также *Файл 1010 *, я рекомендую вам отредактировать его следующим образом

<description> 
    <origin>Thu, 14 Feb 2019 07:43:33</origin>
    <location>NEWDIGATE,SURREY</location>
    <lat>51.163,-0.250</lat>
    <depth>2 km</depth>
    <magnitude>2.4</magnitude>
</description>

Таким образом, вы можете получить доступ к каждой части напрямую с помощью XmlPullParser

...