Пожалуйста, я хочу отобразить значение узла в моем текстовом представлении, но у меня возникают проблемы при получении значения узла.У меня есть необработанный XML-файл с названием страны и узлами с тегами name, alpha2 и diallingcode.Ниже мой код
public class NewTester extends Activity {
/** Called when the activity is first created. */
TextView display;
String getinput;
String data,result;
int code;
InputStream instream;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
display=(TextView)findViewById(R.id.tvdisplay);
String dphoneNumber="2345678";
data=dphoneNumber.substring(0,3);
try {
DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
DocumentBuilder db=dbf.newDocumentBuilder();
instream = getResources().openRawResource(R.raw.mycountries);
Document doc=db.parse(instream,null);
doc.getDocumentElement().normalize();
NodeList nodeList=doc.getElementsByTagName("country");
for(int i=0;i<nodeList.getLength();i++){
Node node=nodeList.item(i);
Element ele=(Element)node;
NodeList Countryname=ele.getElementsByTagName("name");
NodeList CountryAlpha=ele.getElementsByTagName("alpha2");
NodeList Countrydial=ele.getElementsByTagName("diallingcode");
if(Countrydial.item(i).getNodeValue()==data){
result=CountryAlpha.item(i).getNodeValue();
}
}
} catch (ParserConfigurationException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SAXException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
display.setText(""+result);
}
}
Я получаю эту ошибку
03-16 16:19:02.478: E/AndroidRuntime(369): FATAL EXCEPTION: main
03-16 16:19:02.478: E/AndroidRuntime(369): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.tester/com.tester.NewTester}: java.lang.NullPointerException
03-16 16: 19: 02.478: E / AndroidRuntime (369): в android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663) 03-16 16: 19: 02.478: E / AndroidRuntime (369): на android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:2679) 03-16 16: 19: 02.478: E / AndroidRuntime(369): в android.app.ActivityThread.access $ 2300 (ActivityThread.java:125) 03-16 16: 19: 02.478: E / AndroidRuntime (369): в android.app.ActivityThread $ H.handleMessage (ActivityThread.java: 2033) 03-16 16: 19: 02.478: E / AndroidRuntime (369): на android.os.Handler.dispatchMessage (Handler.java:99) 03-16 16: 19: 02.478: E / AndroidRuntime (369):в android.os.Looper.loop (Looper.java:123) 03-16 16: 19: 02.478: E / AndroidRuntime (369): в android.app.ActivityThread.main (ActivityThread.java:4627) 03-16 16: 19: 02.478: E / AndroidRuntime (369): в java.lang.reflect.Method.invokeNative (собственный метод) 03-16 16: 19: 02.478: E / AndroidRuntime (369): в java.lang.reflect.Method.invoke (Method.java:521) 03-16 16: 19: 02.478: E / AndroidRuntime (369): на com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:868) 03-16 16:19: 02.478: E / AndroidRuntime (369): на com.android.internal.os.ZygoteInit.main (ZygoteInit.java:626) 03-16 16: 19: 02.478: E / AndroidRuntime (369): на dalvik.system.NativeStart.main (собственный метод) 03-16 16: 19: 02.478: E / AndroidRuntime (369): вызвано: java.lang.NullPointerException 03-16 16: 19: 02.478: E / AndroidRuntime (369): по адресу.tester.NewTester.onCreate (NewTester.java:61) 03-16 16: 19: 02.478: E / AndroidRuntime (369): в android.app.Instrumentation.callActivityOnCreate (Instrumentation.java:1047) 03-16 16:19: 02.478: E / AndroidRuntime (369): на android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2627) 03-16 16: 19: 02.478: E / AndroidRuntime (369): ... еще 11