java读取xml文件内容

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java读取xml文件内容相关的知识,希望对你有一定的参考价值。

<?xml version="1.0" encoding="utf-8"?>
<HWlist>
<Hardwares category="mode1">
<Hardware HW_Index="index1">
<HW_type>type1/HW_type>
<HW_codename>name1</HW_codename>
<IP>IP1</IP>
<OSIP>IP1</OSIP>
<OSType>OS1</OSType>
</Hardware>
<Hardware HW_Index="index2">
<HW_type>type2/HW_type>
<HW_codename>name1</HW_codename>
<IP>IP2</IP>
<OSIP>IP2</OSIP>
<OSType>OS2</OSType>

</Hardware>
</Hardwares>
</HWlist>
用java自带的,我想读取每个节点里面的内容,我的主要目的是将其取出来,然后和另外一个文件里的内容做比较,比如OSType,是RH532位的,那我该怎么拿到呢,在线等,急,我要实例代码,乱抄的理论的绕道

参考技术A java中不是有个读取xml文件的类吗?之间调用那类读取出来,然后用取节点的方法去取对应节点的里的值。等下给你代码。

public class ReaderXml
private static String filename = "E:\\workplace\\readerxml\\bin\\reader\\xml\\reader.xml";
// private static Config config;
public static void main(String []args) throws Exception
//这里用反射机制
DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();
DocumentBuilder dombuilder=domfac.newDocumentBuilder();
//读取文件流
InputStream is=new FileInputStream(filename);
Document doc=dombuilder.parse(is);
Element root=doc.getDocumentElement();
//获取所有xml节点
NodeList dbinfo=root.getChildNodes();
if(dbinfo!=null)
for(int i=0;i<dbinfo.getLength();i++)
//获取节点判断
Node db=dbinfo.item(i);
//如果是Hardwares节点,也就是你xml文件的最顶处的节点
if(db.getNodeName().equals("Hardwares"))
//获取第二个节点包含的所有节点
NodeList list=db.getChildNodes();
for(int y=0;y<list.getLength();y++)
Node n=list.item(y);
//如果节点等于Hardware
if(n.getNodeName().equals("Hardware"))
//获取Hardware节点中的所有节点
NodeList CnodeList=n.getChildNodes();
//取出Hardware里面的所有节点
for(int k=0;k<CnodeList.getLength();k++)
//取出节点
Node cn=CnodeList.item(k);
//去掉里面的#text文件节点。没用,这个不是你配置的节点,应该是xml文件隐藏的

if(!cn.getNodeName().equals("#text"))
//打印你所配置的所有节点 System.out.println("node["+k+"]="+cn.getNodeName()+" nodeValue["+k+"]="+cn.getTextContent());










//具体你要干嘛自己弄了!追问

我的xml文件里面有好几个hardwares,上面的xml里面是只有一个,然后代码也只能读第一个hardwares里面的元素内容,我该怎么读后面几个呢

追答

不会啊。全部内容都读取出来的啊

本回答被提问者和网友采纳
参考技术B import java.io.*;
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;

public class XMLReaderTest

public static void main(String args[])
Element element =
null;
// 可以使用绝对路劲
File f = new File("test.xml");

// documentBuilder为抽象不能直接实例化(将XML文件转换为DOM文件)
DocumentBuilder db =
null;
DocumentBuilderFactory dbf = null;
try
//
返回documentBuilderFactory对象
dbf =
DocumentBuilderFactory.newInstance();
//
返回db对象用documentBuilderFatory对象获得返回documentBuildr对象
db =
dbf.newDocumentBuilder();

// 得到一个DOM并返回给document对象
Document dt = db.parse(f);
//
得到一个elment根元素
element = dt.getDocumentElement();
//
获得根节点
System.out.println("根元素:" + element.getNodeName());

// 获得根元素下的子节点
NodeList childNodes = element.getChildNodes();

// 遍历这些子节点
for (int i = 0; i < childNodes.getLength(); i++)

// 获得每个对应位置i的结点
Node node1 = childNodes.item(i);
if
("Account".equals(node1.getNodeName()))
//
如果节点的名称为"Account",则输出Account元素属性type
System.out.println("\r\n找到一篇账号.
所属区域: " + node1.getAttributes().getNamedItem("type").getNodeValue() + ".
");
// 获得<Accounts>下的节点
NodeList nodeDetail =
node1.getChildNodes();
// 遍历<Accounts>下的节点
for (int j = 0;
j < nodeDetail.getLength(); j++)
//
获得<Accounts>元素每一个节点
Node detail = nodeDetail.item(j);
if
("code".equals(detail.getNodeName())) //
输出code
System.out.println("卡号: " +
detail.getTextContent());
else if ("pass".equals(detail.getNodeName()))
// 输出pass
System.out.println("密码: " +
detail.getTextContent());
else if ("name".equals(detail.getNodeName()))
// 输出name
System.out.println("姓名: " +
detail.getTextContent());
else if
("money".equals(detail.getNodeName())) //
输出money
System.out.println("余额: " +
detail.getTextContent());






catch (Exception e)
e.printStackTrace();


参考技术C 用dom4j取出数据,如下是代码块

import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

public class XMLPaser
public static void main(String[] args)
paserXML();


public static void paserXML()
SAXReader reader = new SAXReader();
try
// 读取XML文件
Document doc = reader.read("*******.xml");
Element root = doc.getRootElement();
System.out.println(root.getName());
List<Element> param = root.elements();
for (Element element : param)
if(element.attributeValue("OSType").equals("a"))
System.out.println(element.getText());


catch (DocumentException e)
e.printStackTrace();




详情搜索一下dom4j的使用方法。可以直接取出节点的内容,使用element.attributeValue("OSType")取出OS1和OS2
稍微对比一下就可以

不然就直接用substring方法一个个截取吧,自己写很容易出错的。
参考技术D XMLStreamReader reader = inputFactory.createXMLStreamReader(new FileInputStream(new File("xmlPath")));//这里可以替换成一个流
List<Map<String, String>> dataList = new ArrayList<Map<String, String>>();
while (reader.hasNext()) 
int event = reader.next();
if (event == XMLStreamConstants.START_ELEMENT) 
//这里获取你的节点名称
if (reader.getName().equals("Hardware")) 
int attrCount = reader.getAttributeCount();
Map<String, String> dataMap = new HashMap<String, String>();

for (int i = 0; i < attrCount; i++) 
String attrName = reader.getAttributeLocalName(i);
String attrValue = reader.getAttributeValue(i);
// System.out.println("----attrname: "+attrName);
// System.out.println("----attrvalue: "+attrValue);
dataMap.put(attrName, attrValue);

dataList.add(dataMap);


第5个回答  2020-02-26 用dom4j可以读取的,你用嵌套遍历节点的方式应该可以读取到所有节点。

以上是关于java读取xml文件内容的主要内容,如果未能解决你的问题,请参考以下文章

Java里面怎么解析xml文件的内容

java XML添加文本内容

java读取xml文件内容——转自翘首以望

XML文件内容如何读取(C或C++)

java输出xml文件

java文件读取指定内容