java读写xml文件

java源代码
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.xml.sax.SAXException;
public class Operate {
	 public static void main(String[] args) throws Exception
	 {
		 WriteXML(".//conf//12.xml", "searcher.dir", "123");
		 System.err.println(ReadXML(".//conf//12.xml","searcher.dir"));
	 }
	 public static String ReadXML(String path,String name) throws Exception{
			 DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
			 DocumentBuilder db=dbf.newDocumentBuilder();
			 InputStream is=new FileInputStream(path);
			 Document doc=db.parse(is);
			 Element root=doc.getDocumentElement();
			 NodeList datas=root.getChildNodes();
			 String str="";
			 if(datas!=null){
				 for(int i=0;i<datas.getLength();i++){
					 Node data=datas.item(i);
					 if(data.getNodeType()==Node.ELEMENT_NODE){
						 for(Node node=data.getFirstChild();node!=null;node=node.getNextSibling()){
							 if(node.getNodeType()==Node.ELEMENT_NODE){
								 if(node.getNodeName().equals("name")&&node.getTextContent().equals(name)){
									 NodeList nl=node.getParentNode().getChildNodes();
									 for (int k = 0; k <nl.getLength(); k++) { 
										 if (nl.item(k).getNodeName().contains("value")) {
											str=nl.item(k).getTextContent();
										}
										 } 
									}
									 }
								 }
							 }
						 }
					 }
			 return str;
		 }
	
	 public static void WriteXML(String path,String name,String value){
		 DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();
		 try {
			 DocumentBuilder dombuilder=domfac.newDocumentBuilder();
			 InputStream is=new FileInputStream(path);
			 Document doc=dombuilder.parse(is);
			 Element root=doc.getDocumentElement();
			 NodeList datas=root.getChildNodes();
			 if(datas!=null){
				 for(int i=0;i<datas.getLength();i++){
					 Node data=datas.item(i);
					 if(data.getNodeType()==Node.ELEMENT_NODE){
						 for(Node node=data.getFirstChild();node!=null;node=node.getNextSibling()){		 
							 if(node.getNodeName().equals("name")&&node.getTextContent().equals(name)){
								 NodeList nl=node.getParentNode().getChildNodes();
								 for (int k = 0; k <nl.getLength(); k++) { 
									 if (nl.item(k).getNodeName().contains("value")) {
										nl.item(k).setTextContent(value);
									}
									 } 
								}
							 }
						 }
					 }
				 }
			 doc2XmlFile(doc, path);	
			 System.err.println("success");
		 } catch (ParserConfigurationException e) {
				 e.printStackTrace();
				 } catch (FileNotFoundException e) {
					 e.printStackTrace();
					 } catch (SAXException e) {
						 e.printStackTrace();
						 } catch (IOException e) {
							 e.printStackTrace();
							 }
		 }
	 public static boolean doc2XmlFile(Document document, String filename) {
	        boolean flag = true;
	        try {
	           
	            TransformerFactory tFactory = TransformerFactory.newInstance();
	            Transformer transformer = tFactory.newTransformer();
	            DOMSource source = new DOMSource(document);
	            StreamResult result = new StreamResult(new File(filename));
	            transformer.transform(source, result);
	        } catch (Exception ex) {
	            flag = false;
	            ex.printStackTrace();
	        }
	        return flag;
	    }
 }

xml结构

<?xml version="1.0" encoding="UTF-8" standalone="no"?><?xml-stylesheet type="text/xsl" href="configuration.xsl"?>

  
  

   
   
    
    
    
     
     http.agent.name
    
    
    
    
    
     
     my nutch agent
    
    

   
   

   
   
    
    
    
     
     http.agent.version
    
    
    
    
    
     
     1.2
    
    

   
   

   
   
    
    
    
     
     searcher.dir
    
    
    
    
    
     
     123
    
    
    
    
    
     
     index dir
    
    

   
   

  
  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中读取XML文件有多种方式,其中比较常用的是DOM和SAX两种方式。 DOM方式: 1. 加载XML文件 ```java DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); DocumentBuilder db = dbf.newDocumentBuilder(); Document document = db.parse(new File("xmlfile.xml")); ``` 2. 获取根节点 ```java Element root = document.getDocumentElement(); ``` 3. 获取子节点 ```java NodeList nodeList = root.getChildNodes(); ``` 4. 遍历节点 ```java for (int i=0; i<nodeList.getLength(); i++) { Node node = nodeList.item(i); if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; // 获取节点内容 String content = element.getTextContent(); // 获取节点属性 String attribute = element.getAttribute("attributeName"); } } ``` SAX方式: 1. 创建SAX解析器 ```java SAXParserFactory factory = SAXParserFactory.newInstance(); SAXParser saxParser = factory.newSAXParser(); ``` 2. 实现处理器类 ```java class MyHandler extends DefaultHandler { @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { // 处理开始标签 } @Override public void endElement(String uri, String localName, String qName) throws SAXException { // 处理结束标签 } @Override public void characters(char[] ch, int start, int length) throws SAXException { // 处理节点内容 } } ``` 3. 解析XML文件 ```java saxParser.parse(new File("xmlfile.xml"), new MyHandler()); ``` 以上是Java读取XML文件的基本方法,具体使用可以根据需求进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值