很抱歉,我对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>
方法getElementsByTagName的参数区分大小写。所以"Name" ! = "name"和"id" ! = "Id"。更改xml文件元素名称以匹配代码,或者更改代码中的大小写值以匹配xml文件中元素的大小写。
格式化代码,使有问题的行包含几行,这将更容易查明错误在哪里,或者在调试器中运行。
检查您的标签,因为名称和名称、id和id不相同。
eElement.getElementsByTagName("Name")
计算为<code>null</code>(并引发异常)。在您的示例中,请尝试:
eElement.getElementsByTagName("name") //case sensitive!
…这只是“冰山一角”,请注意所有标签名称的大小写敏感性和拼写!
问题内容: 我知道静态方法在类级别。因此,我知道我不需要创建实例来调用静态方法。但我也知道我可以将静态方法(如LIKE)称为实例方法。这是我感到困惑的地方,因为我期望从null对象调用静态方法(就像在调用实例方法中一样)。我真的很感谢一些解释,为什么我错了一个期望。 这是示例代码: 问题答案: 通过实例调用静态方法不需要实例存在。只要编译器能够确定变量的类型,它就可以在评估表达式并丢弃结果后静态进
这是我的父类,有两个名为的方法。带有参数的那个在子类中使用。 这是我的子类,在子类的方法中,我使用父类的方法: 当我尝试显示子类的对象时,我得到以下错误: 线程“main”java.lang.StackOverflowError中出现异常
URL类 来自服务器的最终响应:
我刚刚开始了一个新的项目,正在尝试连接到FireBase。当我试图构建我的项目时,我得到了一个错误:无法解析Android应用程序模块的Gradle配置,所以我查看了构建,它告诉我jCenter()不推荐使用,我应该删除它。当我把它取下来的时候,一切都很好。但是,当我尝试连接到Firebase时,我得到了错误:AbstractDynamicObject$CustomMessageMissingMe