Это XML URL
http://www.eboundservices.com/distribution/vod_new.xml
Как мы разбираем в Android
<Aajkamrankhankaysath p0201="" p0801="" p0901="" p1501="" p1601="" p2201="" p2301="" p2901="" p3001="" p0702="" p2102="" p0303="" p0403="" p0603="" p1003="" p1103="" p1203="" p1303="" p1703="" p1803="" p1903="" p2003="" p2403="" p2503="" p2603="" p2703="" p2803="" p3103="" p0104="" p0204="" p0304="" p0404="" p0704="" p0804="" p0904="" p1004="" p1104="" p1404="" p1504="" p1604="" p1704="" p1804="" p2104="" p2204="" p2304="" p2404="" p2804="" p2904="" p3004="" p0105="" p0205="" p0505="" p0605="" p0705="" p0805="" p0905="" p1205="" p1305="" p1405="" p1505="" p1605="" p1905="" p2005="" p2105="" p2205="" p2305="" p2705="" p2805="" p2905="" p3005="" p0206="" p0306="" p0406="" p0506="" p2306="" p2406="" p2506="">25</Aajkamrankhankaysath>
Я хочу получить как: p0201, p0801, p0901, p1501, p1501 … и так далее
Я хочу сохранить в ArrayList, имею в виду тег <> данные в AaaryList соответственно
Прежде всего, это атрибуты, о которых кто-то уже упоминал. Конечно, иметь такой плохо сформированный XML — плохая идея, даже если веб-сервис большой, я вижу, что он разрабатывается очень плохо. Помимо личных мнений, вам нужно будет создать свой собственный класс, чтобы заполнить список объектов. Вам нужно будет прочитать каждый узел и заполнить каждый атрибут вручную, и никакие сокращения не будут работать (насколько я знаю).
public class TVNode {
String p0210;
String p0801;
String p0901;
// so on an so forth, define String mmembers for every attribute
public TVNode()
{
}
public void setp0210(String _p0210)
{
}
public void setp0801(String _p0801)
{
}
public void setp0901(String _p0901)
{
}
// and getters too of course
}
У вас будет список типов TVNode, вы будете читать XML из файла или веб-ответа, и как только вы его получите, вам нужно будет проанализировать его с помощью некоторого типа XMLDOMParser. Надеюсь, это поможет.
xmlpullparser быстрее, чем загрузка документа. Он точно подходит для примера xml, который есть в вашем вопросе.
XmlPullParser xpp;
XmlPullParserFactory factory = null;
factory = XmlPullParserFactory.newInstance();
xpp = factory.newPullParser();
xpp.setInput(kmlis, "UTF-8"); //todo get your input into inputstreamint eventType = xpp.getEventType();
while (true) {
if (eventType == XmlPullParser.START_TAG) {
if (xpp.getName().equals("aajdsaklhandsksplsb")){
int x = xpp.getAttributeCount();
for (int i = 0;i<x;i++){
String name = xpp.getAttributeName(i);
String value = xpp.getAttributeValue(i)
log.d("test", name + "=" + value);
}
}
}
else if (eventType == XmlPullParser.END_DOCUMENT) {break;}
eventType = xpp.getEventType();
}
Это должен быть худший формат XML, есть какой-то другой парсер вроде XMLPullParser, DOMParser и SAXParser но вы можете использовать xmlPullParser чтобы получить значения атрибутов в соответствии с вашими требованиями.
Вот пример XML:
<message id="[email protected]" from="web.hightect.com" text="Hello World">
<firstname>Marie Josèphe</firstname>
<lastname>Joseph</lastname>
</message>
Вот полный анализатор, и вы можете использовать этот универсальный анализатор для выполнения ваших требований
Пример: вы можете получить идентификатор и текст из первого атрибута
public class New_Generic_Parser {
public static ArrayList<String> list = new ArrayList<String>();
XmlPullParserFactory xmlFactoryObject = null;
String payload,option_text1,option_text2;
public New_Generic_Parser() {
payload = "";
list = new ArrayList<String>();
option_text1 = "";
option_text2 = "";
}
private void parseXMLAndStoreIt(XmlPullParser myParser) {
int event;
try {
event = myParser.getEventType();
while (event != XmlPullParser.END_DOCUMENT) {
String name=myParser.getName();
switch (event){
case XmlPullParser.START_TAG:
if(name.equalsIgnoreCase("user")){
option_text1 = myParser.getAttributeValue(null, "id");
option_text2 = myParser.getAttributeValue(null,"text");
//get attribute from here:
}
break;
case XmlPullParser.TEXT:
if(name.equalsIgnoreCase("user")){
list.add(myParser.getText());
}
break;
case XmlPullParser.END_TAG:
String pic = list.get(0).toString();
byte [] encodeByte=Base64.decode(pic,Base64.DEFAULT);
Bitmap bitmap=BitmapFactory.decodeByteArray(encodeByte, 0, encodeByte.length);
break;
}
event = myParser.next();
}
// parsingComplete = false;
} catch (Exception e) {
e.printStackTrace();
}
}
public void genericparser(String payload){
try {
InputStream stream = new ByteArrayInputStream(payload.getBytes());
xmlFactoryObject = XmlPullParserFactory.newInstance();
XmlPullParser myparser = xmlFactoryObject.newPullParser();
myparser.setFeature(XmlPullParser.FEATURE_PROCESS_NAMESPACES, false);
myparser.setInput(stream, null);
parseXMLAndStoreIt(myparser);
stream.close();
} catch (Exception e) {
// TODO: handle exception
}
}