Android - Analisador de XML
XML significa Extensible Mark-up Language.XML é um formato muito popular e comumente usado para compartilhar dados na Internet. Este capítulo explica como analisar o arquivo XML e extrair as informações necessárias dele.
O Android oferece três tipos de analisadores XML que são DOM,SAX and XMLPullParser. Entre todos eles, o android recomenda o XMLPullParser por ser eficiente e fácil de usar. Portanto, vamos usar XMLPullParser para analisar XML.
A primeira etapa é identificar os campos nos dados XML nos quais você está interessado. Por exemplo. No XML fornecido a seguir, estamos interessados em obter apenas a temperatura.
<?xml version="1.0"?>
<current>
<city id="2643743" name="London">
<coord lon="-0.12574" lat="51.50853"/>
<country>GB</country>
<sun rise="2013-10-08T06:13:56" set="2013-10-08T17:21:45"/>
</city>
<temperature value="289.54" min="289.15" max="290.15" unit="kelvin"/>
<humidity value="77" unit="%"/>
<pressure value="1025" unit="hPa"/>
</current>
XML - Elementos
Um arquivo xml consiste em muitos componentes. Aqui está a tabela que define os componentes de um arquivo XML e sua descrição.
Sr. Não | Descrição do componente |
---|---|
1 |
Prolog Um arquivo XML começa com um prólogo. A primeira linha que contém as informações sobre um arquivo é o prólogo |
2 |
Events Um arquivo XML possui muitos eventos. O evento poderia ser assim. O documento começa, termina o documento, começa a tag, termina a tag e texto etc. |
3 |
Text Além de tags e eventos, o arquivo xml também contém texto simples. Tal comoGB é um texto na marca do país. |
4 |
Attributes Atributos são as propriedades adicionais de uma tag, como valor etc. |
XML - análise
Na próxima etapa, criaremos o objeto XMLPullParser, mas para criá-lo, primeiro criaremos o objeto XmlPullParserFactory e, em seguida, chamaremos seu método newPullParser () para criar XMLPullParser. Sua sintaxe é fornecida abaixo -
private XmlPullParserFactory xmlFactoryObject = XmlPullParserFactory.newInstance();
private XmlPullParser myparser = xmlFactoryObject.newPullParser();
A próxima etapa envolve a especificação do arquivo para XmlPullParser que contém XML. Pode ser um arquivo ou um Stream. No nosso caso, é um fluxo. Sua sintaxe é fornecida abaixo -
myparser.setInput(stream, null);
A última etapa é analisar o XML. Um arquivo XML consiste em eventos, Nome, Texto, AttributesValue etc. Portanto, XMLPullParser tem uma função separada para analisar cada um dos componentes do arquivo XML. Sua sintaxe é fornecida abaixo -
int event = myParser.getEventType();
while (event != XmlPullParser.END_DOCUMENT) {
String name=myParser.getName();
switch (event){
case XmlPullParser.START_TAG:
break;
case XmlPullParser.END_TAG:
if(name.equals("temperature")){
temperature = myParser.getAttributeValue(null,"value");
}
break;
}
event = myParser.next();
}
O método getEventTyperetorna o tipo de evento que acontece. por exemplo: início do documento, início da tag, etc. O métodogetName retorna o nome da tag e uma vez que estamos interessados apenas na temperatura, então apenas verificamos na declaração condicional que se obtivermos uma tag de temperatura, chamamos o método getAttributeValue para nos retornar o valor da etiqueta de temperatura.
Além desses métodos, existem outros métodos fornecidos por esta classe para analisar melhor os arquivos XML. Esses métodos estão listados abaixo -
Sr. Não | Método e descrição |
---|---|
1 |
getAttributeCount() Este método retorna apenas o número de atributos da tag de início atual |
2 |
getAttributeName(int index) Este método retorna o nome do atributo especificado pelo valor do índice |
3 |
getColumnNumber() Este método retorna o Retorna o número da coluna atual, começando em 0. |
4 |
getDepth() Este método retorna Retorna a profundidade atual do elemento. |
5 |
getLineNumber() Retorna o número da linha atual, começando em 1. |
6 |
getNamespace() Este método retorna o URI do espaço de nomes do elemento atual. |
7 |
getPrefix() Este método retorna o prefixo do elemento atual |
8 |
getName() Este método retorna o nome da tag |
9 |
getText() Este método retorna o texto para aquele elemento específico |
10 |
isWhitespace() Este método verifica se o evento TEXT atual contém apenas caracteres de espaço em branco. |
Exemplo
Aqui está um exemplo que demonstra o uso do XML DOM Parser. Ele cria um aplicativo básico que permite analisar XML.
Para experimentar este exemplo, você pode executá-lo em um dispositivo real ou em um emulador.
Passos | Descrição |
---|---|
1 | Você usará o Android Studio para criar um aplicativo Android em um pacote com.example.sairamkrishna.myapplication. |
2 | Modifique o arquivo src / MainActivity.java para adicionar o código necessário. |
3 | Modifique res / layout / activity_main para adicionar os respectivos componentes XML |
4 | Crie um novo arquivo XML em Assets Folder / file.xml |
5 | Modifique AndroidManifest.xml para adicionar a permissão de internet necessária |
6 | Execute o aplicativo e escolha um dispositivo Android em execução, instale o aplicativo nele e verifique os resultados |
A seguir está o conteúdo do arquivo de atividade principal modificado MainActivity.java.
package com.example.sairamkrishna.myapplication;
import java.io.InputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import android.app.Activity;
import android.os.Bundle;
import android.widget.TextView;
public class MainActivity extends Activity {
TextView tv1;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tv1=(TextView)findViewById(R.id.textView1);
try {
InputStream is = getAssets().open("file.xml");
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(is);
Element element=doc.getDocumentElement();
element.normalize();
NodeList nList = doc.getElementsByTagName("employee");
for (int i=0; i<nList.getLength(); i++) {
Node node = nList.item(i);
if (node.getNodeType() == Node.ELEMENT_NODE) {
Element element2 = (Element) node;
tv1.setText(tv1.getText()+"\nName : " + getValue("name", element2)+"\n");
tv1.setText(tv1.getText()+"Surname : " + getValue("surname", element2)+"\n");
tv1.setText(tv1.getText()+"-----------------------");
}
}
} catch (Exception e) {e.printStackTrace();}
}
private static String getValue(String tag, Element element) {
NodeList nodeList = element.getElementsByTagName(tag).item(0).getChildNodes();
Node node = nodeList.item(0);
return node.getNodeValue();
}
}
A seguir está o conteúdo de Assets/file.xml.
<?xml version="1.0"?>
<records>
<employee>
<name>Sairamkrishna</name>
<surname>Mammahe</surname>
<salary>50000</salary>
</employee>
<employee>
<name>Gopal </name>
<surname>Varma</surname>
<salary>60000</salary>
</employee>
<employee>
<name>Raja</name>
<surname>Hr</surname>
<salary>70000</salary>
</employee>
</records>
A seguir está o conteúdo modificado do xml res/layout/activity_main.xml.
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity">
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</RelativeLayout>
A seguir está o conteúdo de AndroidManifest.xml Arquivo.
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.sairamkrishna.myapplication" >
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
Vamos tentar executar nosso aplicativo que acabamos de modificar. Suponho que você tenha criado o seuAVDao fazer a configuração do ambiente. Para executar o aplicativo do Android Studio, abra um dos arquivos de atividade do seu projeto e clique no ícone Executar na barra de ferramentas. O Android Studio instala o aplicativo em seu AVD e o inicia e se tudo estiver bem com sua configuração e aplicativo, ele será exibido a seguir a janela do emulador -