当前位置: 首页 > 知识库问答 >
问题:

为什么我会得到NullPointerException错误

张卓
2023-03-14

很抱歉,我对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() }; 当我运行代码时。

下面是解析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个答案

陶裕
2023-03-14

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

花品
2023-03-14

格式化代码,使有问题的行包含几行,这将更容易查明错误在哪里,或者在调试器中运行。

检查您的标签,因为名称和名称、id和id不相同。

仲孙昊焱
2023-03-14
eElement.getElementsByTagName("Name")

计算为<code>null</code>(并引发异常)。在您的示例中,请尝试:

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

…这只是“冰山一角”,请注意所有标签名称的大小写敏感性和拼写!

 类似资料: