xpath는 xml 문서에서 정보를 찾는 언어입니다. xpath는 XML 문서의 요소와 속성을 탐색하는 데 사용됩니다. 반환 값은 노드, 노드 컬렉션, 텍스트, 노드와 텍스트의 혼합 등일 수 있습니다.
이 문서를 연구하기 전에 XML 노드, 요소, 속성, 텍스트, 처리 지침, 주석, 루트 노드, 네임스페이스, 노드 관계는 물론 xpath에 대해 어느 정도 이해하고 있어야 합니다.
XML 학습 주소: http://www.runoob.com/xml/xml-tutorial.html
XPath 기본 구문 학습 주소: http://www.runoob.com/xpath/xpath-tutorial.html
xpath 공식 문서: https://yunpan.cn/cvc4tEIGy5EvS 액세스 비밀번호 9d16
이 기사에서는 주로 xpath 작업을 사용하여 Java에서 xml을 작동하는 방법을 소개합니다.
1) 먼저 dom4j에서 xpath 기술을 사용하는 방법
xPath가 지원하는 jar 패키지를 가져옵니다. jaxen-1.1-beta-6.jar(먼저 dom4j 패키지를 가져옵니다. dom4j 다운로드 주소: http://www.dom4j.org/dom4j-1.6.1/).
패키지를 안내한 후 사진과 같이
패키지를 import하는 방법을 모르신다면 제 이전 블로그를 참고해주세요: Java에서 xml 노드 가져오기 및 xml 문서 노드 읽기 요약
2) 두 가지가 있습니다 Java Point에서 xpath 메소드를 사용하는 주요 방법:
List
노드 selectSingleNode("xpath 표현식")
다음 예제를 사용하여 사용법을 설명합니다.
1. selectNodes 사용 방법:
package com.vastsum.demo; import java.io.File; import java.io.FileOutputStream; import java.util.List; import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.Node; import org.dom4j.io.OutputFormat; import org.dom4j.io.SAXReader; import org.dom4j.io.XMLWriter; /** * * @author shutu008 *selectNode的使用方法 */ public class xpathDemo { public static void main(String[] args) throws Exception { Document doc = new SAXReader().read(new File("./src/contact.xml")); /** * @param xpath 表示xpath语法变量 */ String xpath=""; /** * 1. / 绝对路径 表示从xml的根位置开始或子元素(一个层次结构) */ xpath = "/contactList"; xpath = "/contactList/contact"; /** * 2. // 相对路径 表示不分任何层次结构的选择元素。 */ xpath = "//contact/name"; xpath = "//name"; /** * 3. * 通配符 表示匹配所有元素 */ xpath = "/contactList/*"; //根标签contactList下的所有子标签 xpath = "/contactList//*";//根标签contactList下的所有标签(不分层次结构) /** * 4. [] 条件 表示选择什么条件下的元素 */ //带有id属性的contact标签 xpath = "//contact[@id]"; //第二个的contact标签 xpath = "//contact[2]"; //选择最后一个contact标签 xpath = "//contact[last()]"; /** * 5. @ 属性 表示选择属性节点 */ xpath = "//@id"; //选择id属性节点对象,返回的是Attribute对象 xpath = "//contact[not(@id)]";//选择不包含id属性的contact标签节点 xpath = "//contact[@id='002']";//选择id属性值为002的contact标签 xpath = "//contact[@id='001' and @name='eric']";//选择id属性值为001,且name属性为eric的contact标签 /** *6. text() 表示选择文本内容 */ //选择name标签下的文本内容,返回Text对象 xpath = "//name/text()"; xpath = "//contact/name[text()='张三']";//选择姓名为张三的name标签 List<Node> list = doc.selectNodes(xpath); for (Node node : list) { System.out.println(node); } //写出xml文件 //输出位置 FileOutputStream out = new FileOutputStream("d:/contact.xml"); //指定格式 OutputFormat format = OutputFormat.createPrettyPrint(); format.setEncoding("utf-8"); XMLWriter writer = new XMLWriter(out,format); //写出内容 writer.write(doc); //关闭资源 writer.close(); } }
2. selectSingleNode 사용 방법
package com.vastsum.demo; import java.io.File; import java.util.Iterator; import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.io.SAXReader; /** * * @author shutu008 *selectSingleNode的使用 */ public class xpathDemo1{ public static void main(String[] args) throws Exception{ //读取XML文件,获得document对象 SAXReader saxReader = new SAXReader(); Document doc = saxReader.read(new File("./src/contact.xml")); //使用xpath获取某个节点 String xpath = ""; //对contact元素 id="001"的节点,操作 xpath = "//contact[@id = '001']"; Element contactElem = (Element)doc.selectSingleNode(xpath); //设置这个节点的属性值 contactElem.addAttribute("name", "001"); //输出这个节点的所有属性值 for(Iterator it = contactElem.attributeIterator();it.hasNext();){ Attribute conAttr = (Attribute)it.next(); String conTxt = conAttr.getValue(); String conAttrName = conAttr.getName(); System.out.println(conAttrName+" = "+conTxt); } } }