#java #android #xmlpullparser
#java #Android #xmlpullparser — анализатор
Вопрос:
Я проанализировал XML-канал, но в одном из тегов я хочу продолжить анализ данных, но не уверен, как это сделать? Для этого я использую XmlPullParser в пакете, затем информация сохраняется в пакете Widgetclass, перед отправкой в мой mainactivity через inent с использованием широковещательного приемника.
в настоящее время код вызывает только одно поле анализируемой информации, но при вызове большего количества возникает проблема содержимого несортированного XML-тега. Кажется, я не могу заставить метод split.String работать здесь, должен ли он быть в классе widget, в котором я должен хранить информацию, или в mainactivity?
// синтаксический анализатор public static WidgetClass[] parseFeed(String content) {
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 amp;amp; 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. Не могли бы вы, пожалуйста, привести пример того, какой текст вы хотели бы разделить и какой был бы желаемый результат?
2. Это пример текста, который нужно разделить:<описание> Исходная дата / время: Чт, 14 февраля 2019 07:43:33 ; Местоположение: НЬЮДИГЕЙТ, СУРРЕЙ ; Широта / долгота: 51.163,-0.250 ; Глубина: 2 км ; Магнитуда: 2.4 </description> Надеюсь, будет разделение это на; между каждой записью и помещением этого в массив
Ответ №1:
Ваш пример строки:
<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 "
Если вы также редактируете xml
файл, я рекомендую вам отредактировать его следующим образом
<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