我为什么会出现NullPointerException错误

时间:2015-04-20 16:20:47

标签: java xml

很抱歉,我对Java知之甚少。我接受了这个代码来接管。基本上,当我运行代码时,我在String[] patient = {eElement.getElementsByTagName("Name").item(0).getTextContent(), eElement.getElementsByTagName("ID").item(0).getTextContent(), eElement.getElementsByTagName("acquisitionDate").item(0).getTextContent(), eElement.getElementsByTagName("pages").item(0).getTextContent() };行上得到NullPointerException。

这是解析XML的块

//parse array of string arrays from xml file that represent the patient list we expect to see, needs to be sorted by acquisition date, in reverse chronological order.
File fxmlFile = new File("patientList.xml");
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(fxmlFile);

doc.getDocumentElement().normalize(); //should not be necessary but recommended (http://stackoverflow.com/questions/13786607/normalization-in-dom-parsing-with-java-how-does-it-work)

NodeList nList = doc.getElementsByTagName("patient");

String[][] retList = new String[nList.getLength()][4];

for(int i = 0; i < nList.getLength(); i++) {
Node nNode = nList.item(i);
Element eElement = (Element)nNode;
String[] patient = {eElement.getElementsByTagName("Name").item(0).getTextContent(), eElement.getElementsByTagName("ID").item(0).getTextContent(), eElement.getElementsByTagName("acquisitionDate").item(0).getTextContent(), eElement.getElementsByTagName("pages").item(0).getTextContent() };

retList[i] = patient;
}

这是Improts,不确定是否需要

package test.java.WebReview.Tests;

import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
import org.testng.Assert;
import main.java.WebReview.Pages.*;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import java.io.File;
import java.util.ArrayList;
import java.util.List;

这是XML文件

<?xml version="1.0"?>
<patients>
<patient>
<acquisitionDate>2015-04-03T10:03:49.0000000</acquisitionDate>
<id>9876543230</id>
<name>autoTestLast30, autoTestFirst30</name>
<pages>3</pages>
</patient>
</patients>

3 个答案:

答案 0 :(得分:2)

eElement.getElementsByTagName("Name")

在您的示例中评估为null(并引发异常),请尝试:

eElement.getElementsByTagName("name") //case sensitive!

..这只是冰山的一小部分&#34;请注意所有标签名称的区分大小写和拼写!

答案 1 :(得分:1)

格式化代码,使违规行占用几行,这样可以更容易查明错误的位置,或在调试器中运行。

检查你的标签,因为名称和名称,ID和ID不一样。

答案 2 :(得分:1)

方法getElementsByTagName的参数区分大小写。所以“名称”!=“名称”“id”!=“Id”。更改xml文件元素名称以匹配您的代码,或者更改代码中的值以匹配xml文件中元素的大小写。