अपाचे Xerces - त्वरित गाइड
XML क्या है?
XML एक सरल पाठ-आधारित भाषा है जिसे सादे पाठ प्रारूप में डेटा को संग्रहीत और परिवहन करने के लिए डिज़ाइन किया गया था। यह एक्स्टेंसिबल मार्कअप लैंग्वेज के लिए है। XML की कुछ मुख्य विशेषताएं निम्नलिखित हैं।
XML एक मार्कअप भाषा है।
XML HTML जैसी टैग आधारित भाषा है।
XML टैग HTML की तरह पूर्वनिर्धारित नहीं हैं।
आप अपने स्वयं के टैग को परिभाषित कर सकते हैं यही कारण है कि इसे एक्स्टेंसिबल भाषा कहा जाता है।
XML टैग स्व-वर्णनात्मक होने के लिए डिज़ाइन किए गए हैं।
XML डेटा स्टोरेज और ट्रांसपोर्टेशन के लिए W3C की सिफारिश है।
उदाहरण
<?xml version = "1.0"?>
<Class>
<Name>First</Name>
<Sections>
<Section>
<Name>A</Name>
<Students>
<Student>Rohan</Student>
<Student>Mohan</Student>
<Student>Sohan</Student>
<Student>Lalit</Student>
<Student>Vinay</Student>
</Students>
</Section>
<Section>
<Name>B</Name>
<Students>
<Student>Robert</Student>
<Student>Julie</Student>
<Student>Kalie</Student>
<Student>Michael</Student>
</Students>
</Section>
</Sections>
</Class>
लाभ
XML द्वारा प्रदान किए गए लाभ निम्नलिखित हैं -
Technology agnostic- सादा पाठ होने के नाते, XML तकनीकी स्वतंत्र है। इसका उपयोग किसी भी तकनीक द्वारा डेटा स्टोरेज और ट्रांसमिशन उद्देश्य के लिए किया जा सकता है।
Human readable- एक्सएमएल सरल पाठ प्रारूप का उपयोग करता है। यह मानवीय पठनीय और समझने योग्य है।
Extensible - XML में, कस्टम टैग्स बहुत आसानी से बनाए और इस्तेमाल किए जा सकते हैं।
Allow Validation - XSD, DTD और XML संरचना का उपयोग करके आसानी से मान्य किया जा सकता है।
नुकसान
XML उपयोग के नुकसान निम्नलिखित हैं -
Redundant Syntax - आम तौर पर XML फ़ाइल में कई दोहराव शब्द होते हैं।
Verbose - एक क्रिया भाषा होने के नाते, XML फ़ाइल का आकार संचरण और भंडारण लागत को बढ़ाता है।
यह अध्याय आपको विंडोज़ और लिनक्स पर आधारित सिस्टम पर अपाचे ज़ेर्सेस स्थापित करने की प्रक्रिया के माध्यम से लेता है। Apache Xerces को आसानी से स्थापित किया जा सकता है और बिना किसी जटिल सेटअप प्रक्रियाओं के कुछ सरल चरणों का पालन करके अपने वर्तमान जावा वातावरण के साथ एकीकृत किया जा सकता है। स्थापना करते समय उपयोगकर्ता प्रशासन की आवश्यकता होती है।
सिस्टम आवश्यकताएं
JDK | जावा एसई 2 जेडडीके 1.5 या इसके बाद के संस्करण |
याद | 1 जीबी रैम (अनुशंसित) |
डिस्क में जगह | कोई न्यूनतम आवश्यकता नहीं |
ऑपरेटिंग सिस्टम संस्करण | विंडोज एक्सपी या उससे ऊपर, लिनक्स |
चलिए अब Apache Xerces को स्थापित करने के चरणों के साथ आगे बढ़ते हैं।
चरण 1: अपने जावा इंस्टॉलेशन को सत्यापित करें
सबसे पहले, आपको अपने सिस्टम पर जावा सॉफ्टवेयर डेवलपमेंट किट (एसडीके) इंस्टॉल करना होगा। इसे सत्यापित करने के लिए, जिस प्लेटफ़ॉर्म पर आप काम कर रहे हैं, उसके आधार पर किसी भी दो कमांड को निष्पादित करें।
यदि जावा इंस्टॉलेशन सफल है, तो यह आपके जावा इंस्टॉलेशन के वर्तमान संस्करण और विनिर्देश को प्रदर्शित करेगा। निम्न तालिका में एक नमूना आउटपुट दिया गया है।
मंच | आदेश | नमूना आउटपुट |
---|---|---|
खिड़कियाँ | कमांड कंसोल खोलें और टाइप करें: java -version | जावा संस्करण "1.7.0_60" जावा (टीएम) एसई रन टाइम एनवायरनमेंट (बिल्ड 1.7.0_60-बी 19) जावा हॉटस्पॉट (टीएम) 64-बिट सर्वर वीएम (24.60b09 का निर्माण, मिश्रित मोड) |
लिनक्स | ओपन कमांड टर्मिनल और टाइप करें: $ java -version | जावा संस्करण "1.7.0_25" ओपन JDK रनटाइम एनवायरनमेंट (rhel-2.3.10.4.el6_4-x86_64) ओपन JDK 64-बिट सर्वर VM (23.7-b01, मिश्रित मोड का निर्माण) |
हम मानते हैं कि इस ट्यूटोरियल के पाठकों के पास अपने सिस्टम पर जावा एसडीके संस्करण 1.7.0_60 है।
यदि आपके पास जावा एसडीके नहीं है, तो इसका वर्तमान संस्करण डाउनलोड करें https://www.oracle.com/technetwork/java/javase/downloads/index.html और इसे स्थापित किया है।
चरण 2: अपने जावा पर्यावरण सेट करें
वातावरण चर JAVA_HOME को आधार निर्देशिका स्थान पर इंगित करने के लिए सेट करें जहाँ जावा आपकी मशीन पर स्थापित है। उदाहरण के लिए,
अनु क्रमांक। | मंच और विवरण |
---|---|
1 | Windows JAVA_HOME को C: \ ProgramFiles \ java \ jdk1.7.0_60 पर सेट करें |
2 | Linux निर्यात JAVA_HOME = / usr / स्थानीय / जावा-वर्तमान |
जावा कंपाइलर स्थान का पूरा पथ सिस्टम पथ में जोड़ें।
अनु क्रमांक। | मंच और विवरण |
---|---|
1 | Windows स्ट्रिंग "C: \ Program Files \ Java \ jdk1.7.0_60 \ bin" सिस्टम चर पथ के अंत में जोड़ें। |
2 | Linux निर्यात पाथ = $ पाथ: $ जाव_होम / बिन / |
ऊपर बताए अनुसार कमांड प्रॉम्प्ट से कमांड जावा संस्करण निष्पादित करें।
चरण 3: अपाचे Xerces लाइब्रेरी स्थापित करें
से Apache Xerces का नवीनतम संस्करण डाउनलोड करें https://xerces.apache.org/mirrors.cgi"और इसकी सामग्री को एक फ़ोल्डर में अनज़िप करें जहां से आवश्यक पुस्तकालयों को आपके जावा प्रोग्राम से जोड़ा जा सकता है। मान लें कि फाइलें C ड्राइव पर एक फ़ोल्डर xerces-2_11_0 में एकत्र की गई हैं।
उपरोक्त चित्र में हाइलाइट किए गए पाँच जार का पूरा पथ CLASSPATH में जोड़ें।
अनु क्रमांक। | मंच और विवरण |
---|---|
1 | Windows उपयोगकर्ता चर CLASSPATH के अंत में निम्नलिखित तार जोड़ें - C: \ xerces-2_11_0 \ resolver.jar; C: \ xerces-2_11_0 \ serializer.jar; C: \ xerces-2_11_0 \ xercesImpl.jar; C: \ xerces-2_11_0 \ xercesSamples.jar; C: \ xerces-2_11_0 \ एक्सएमएल-apis.jar; |
2 | Linux निर्यात क्लास = $ क्लास - /usr/share/xerces-2_11_0\resolver.jar; /usr/share/xerces-2_11_0\serializer.jar; /usr/share/xerces-2_11_0\xercesImpl.jar; /usr/share/xerces-2_11_0\xercesSamples.jar; /usr/share/xerces-2_11_0\xml-apis.jar; |
Apache Xerces2 क्या है?
Xerces2 एक जावा आधारित प्रोसेसर है और XML पार्सिंग एपीआई मानकों का पालन करने के लिए मानक इंटरफेस और कार्यान्वयन प्रदान करता है -
दस्तावेज़ ऑब्जेक्ट मॉडल (DOM) स्तर 3
XML (SAX) 2.0.2 के लिए सरल एपीआई
XML (StAX) 1.0 इवेंट API के लिए स्ट्रीमिंग एपीआई
XML प्रसंस्करण के लिए जावा एपीआई (JAXP) 1.4
XML पार्सिंग क्या है?
पार्सिंग एक्सएमएल डेटा को एक्सेस करने या एक या दूसरे तरीके से डेटा को संशोधित करने के लिए एक्सएमएल दस्तावेज़ के माध्यम से जाने को संदर्भित करता है।
XML पार्सर क्या है?
XML पार्सर एक XML दस्तावेज़ में मौजूद डेटा तक पहुंचने या संशोधित करने का एक तरीका प्रदान करता है। जावा XML दस्तावेज़ को पार्स करने के लिए कई विकल्प प्रदान करता है। निम्नलिखित विभिन्न प्रकार के पार्सर हैं जो आमतौर पर XML दस्तावेजों को पार्स करने के लिए उपयोग किए जाते हैं।
Dom Parser - दस्तावेज़ की पूरी सामग्री को लोड करके और मेमोरी में इसके पूर्ण श्रेणीबद्ध पेड़ का निर्माण करके दस्तावेज़ को पार्स करता है।
SAX Parser- घटना के आधार पर दस्तावेज़ को ट्रिगर करता है। मेमोरी में पूरा दस्तावेज लोड नहीं करता है।
StAX Parser - दस्तावेज़ को इसी तरह के फैशन में एसएएक्स पार्सर के लिए, लेकिन एक अधिक कुशल तरीके से तैयार करता है।
अब, हम अपने बाद के अध्यायों में Apache Xerces लाइब्रेरी का उपयोग करके प्रत्येक पार्सर को विस्तृत करेंगे।
दस्तावेज़ ऑब्जेक्ट मॉडल वर्ल्ड वाइड वेब कंसोर्टियम (W3C) की एक आधिकारिक सिफारिश है। यह एक इंटरफ़ेस को परिभाषित करता है जो प्रोग्राम को XML दस्तावेजों की शैली, संरचना और सामग्री तक पहुंचने और अद्यतन करने में सक्षम बनाता है। XML पार्सर्स जो डोम का समर्थन करते हैं, उस इंटरफ़ेस को लागू करते हैं।
कब इस्तेमाल करें?
जब आपको DOM पार्सर का उपयोग करना चाहिए -
आपको किसी दस्तावेज़ की संरचना के बारे में बहुत कुछ जानने की आवश्यकता है।
आपको दस्तावेज़ के हिस्सों को चारों ओर ले जाने की आवश्यकता है (उदाहरण के लिए, आप कुछ तत्वों को क्रमबद्ध करना चाह सकते हैं)।
आपको दस्तावेज़ में एक से अधिक बार जानकारी का उपयोग करने की आवश्यकता है।
क्या आपको मिला?
जब आप किसी XML दस्तावेज़ को DOM पार्सर के साथ पार्स करते हैं, तो आपको एक ट्री संरचना मिलती है जिसमें आपके दस्तावेज़ के सभी तत्व शामिल होते हैं। DOM विभिन्न प्रकार के फ़ंक्शन प्रदान करता है जिनका उपयोग आप दस्तावेज़ की सामग्री और संरचना की जांच करने के लिए कर सकते हैं।
लाभ
DOM दस्तावेज़ संरचनाओं में हेरफेर करने के लिए एक सामान्य इंटरफ़ेस है। इसके डिजाइन लक्ष्यों में से एक यह है कि एक डोम-कंप्लेंट पार्सर के लिए लिखा गया जावा कोड बिना बदलाव के किसी अन्य डोम-कंप्लेंट पार्सर पर चलना चाहिए।
डोम इंटरफेस
DOM कई Java इंटरफेस को परिभाषित करता है। यहाँ सबसे आम इंटरफेस हैं -
Node - DOM का आधार डेटाटाइप।
Element - जिन वस्तुओं से आप निपटेंगे उनमें से अधिकांश तत्व हैं।
Attr - किसी तत्व की विशेषता का प्रतिनिधित्व करता है।
Text - एक तत्व या Attr की वास्तविक सामग्री।
Document- पूरे XML दस्तावेज़ का प्रतिनिधित्व करता है। दस्तावेज़ ऑब्जेक्ट को अक्सर DOM ट्री के रूप में संदर्भित किया जाता है।
आम डोम तरीके
जब आप DOM के साथ काम कर रहे हैं, तो कई तरीके हैं जो अक्सर उपयोग किए जाते हैं -
Document.getDocumentElement() - दस्तावेज़ के मूल तत्व को लौटाता है।
Node.getFirstChild() - दिए गए नोड का पहला बच्चा लौटाता है।
Node.getLastChild() - दिए गए नोड का अंतिम बच्चा लौटाता है।
Node.getNextSibling() - ये विधियाँ किसी दिए गए नोड का अगला सिबलिंग लौटाती हैं।
Node.getPreviousSibling() - ये विधियाँ किसी दिए गए नोड का पिछला सिबलिंग लौटाती हैं।
Node.getAttribute(attrName) - दिए गए नोड के लिए, अनुरोधित नाम के साथ विशेषता लौटाता है।
डोम का उपयोग करने के लिए कदम
DOM पार्सर का उपयोग करके दस्तावेज़ को पार्स करते समय निम्नलिखित चरणों का उपयोग किया जाता है।
XML- संबंधित पैकेज आयात करें।
एक डॉक्यूमेंट बनाएं
फ़ाइल या स्ट्रीम से एक दस्तावेज़ बनाएँ
मूल तत्व को निकालें
गुण का परीक्षण करें
उप-तत्वों की जांच करें
XML- संबंधित पैकेज आयात करें
import org.w3c.dom.*;
import javax.xml.parsers.*;
import java.io.*;
एक डॉक्यूमेंट बनाएं
DocumentBuilderFactory factory =
DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
फ़ाइल या स्ट्रीम से एक दस्तावेज़ बनाएँ
StringBuilder xmlStringBuilder = new StringBuilder();
xmlStringBuilder.append("<?xml version = "1.0"?> <class> </class>");
ByteArrayInputStream input = new ByteArrayInputStream(
xmlStringBuilder.toString().getBytes("UTF-8"));
Document doc = builder.parse(input);
मूल तत्व को निकालें
Element root = document.getDocumentElement();
गुण का परीक्षण करें
//returns specific attribute
getAttribute("attributeName");
//returns a Map (table) of names/values
getAttributes();
उप-तत्वों की जांच करें
//returns a list of subelements of specified name
getElementsByTagName("subelementName");
//returns a list of all child nodes
getChildNodes();
Demo Example
यहाँ इनपुट xml फ़ाइल है जिसे हमें पार्स करने की आवश्यकता है -
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
डेमो उदाहरण
DomParserDemo.java
package com.tutorialspoint.xml;
import java.io.File;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Element;
public class DomParserDemo {
public static void main(String[] args){
try {
File inputFile = new File("input.txt");
DocumentBuilderFactory dbFactory
= DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(inputFile);
doc.getDocumentElement().normalize();
System.out.println("Root element :"
+ doc.getDocumentElement().getNodeName());
NodeList nList = doc.getElementsByTagName("student");
System.out.println("----------------------------");
for (int temp = 0; temp < nList.getLength(); temp++) {
Node nNode = nList.item(temp);
System.out.println("\nCurrent Element :"
+ nNode.getNodeName());
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
System.out.println("Student roll no : "
+ eElement.getAttribute("rollno"));
System.out.println("First Name : "
+ eElement
.getElementsByTagName("firstname")
.item(0)
.getTextContent());
System.out.println("Last Name : "
+ eElement
.getElementsByTagName("lastname")
.item(0)
.getTextContent());
System.out.println("Nick Name : "
+ eElement
.getElementsByTagName("nickname")
.item(0)
.getTextContent());
System.out.println("Marks : "
+ eElement
.getElementsByTagName("marks")
.item(0)
.getTextContent());
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
Root element :class
----------------------------
Current Element :student
Student roll no : 393
First Name : Dinkar
Last Name : Kad
Nick Name : Dinkar
Marks : 85
Current Element :student
Student roll no : 493
First Name : Vineet
Last Name : Gupta
Nick Name : Vinni
Marks : 95
Current Element :student
Student roll no : 593
First Name : Jasvir
Last Name : Singh
Nick Name : Jazz
Marks : 90
डेमो उदाहरण
यहाँ इनपुट xml फ़ाइल है जिसे हमें क्वेरी करने की आवश्यकता है -
<?xml version = "1.0"?>
<cars>
<supercars company = "Ferrari">
<carname type = "formula one">Ferarri 101</carname>
<carname type = "sports car">Ferarri 201</carname>
<carname type = "sports car">Ferarri 301</carname>
</supercars>
<supercars company = "Lamborgini">
<carname>Lamborgini 001</carname>
<carname>Lamborgini 002</carname>
<carname>Lamborgini 003</carname>
</supercars>
<luxurycars company = "Benteley">
<carname>Benteley 1</carname>
<carname>Benteley 2</carname>
<carname>Benteley 3</carname>
</luxurycars>
</cars>
डेमो उदाहरण
QueryXmlFileDemo.java
package com.tutorialspoint.xml;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
import org.w3c.dom.Document;
import org.w3c.dom.NodeList;
import org.w3c.dom.Node;
import org.w3c.dom.Element;
import java.io.File;
public class QueryXmlFileDemo {
public static void main(String argv[]) {
try {
File inputFile = new File("input.txt");
DocumentBuilderFactory dbFactory =
DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(inputFile);
doc.getDocumentElement().normalize();
System.out.print("Root element: ");
System.out.println(doc.getDocumentElement().getNodeName());
NodeList nList = doc.getElementsByTagName("supercars");
System.out.println("----------------------------");
for (int temp = 0; temp < nList.getLength(); temp++) {
Node nNode = nList.item(temp);
System.out.println("\nCurrent Element :");
System.out.print(nNode.getNodeName());
if (nNode.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) nNode;
System.out.print("company : ");
System.out.println(eElement.getAttribute("company"));
NodeList carNameList =
eElement.getElementsByTagName("carname");
for (int count = 0;
count < carNameList.getLength(); count++) {
Node node1 = carNameList.item(count);
if (node1.getNodeType() ==
node1.ELEMENT_NODE) {
Element car = (Element) node1;
System.out.print("car name : ");
System.out.println(car.getTextContent());
System.out.print("car type : ");
System.out.println(car.getAttribute("type"));
}
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
Root element :cars
----------------------------
Current Element :supercars
company : Ferrari
car name : Ferarri 101
car type : formula one
car name : Ferarri 201
car type : sports car
car name : Ferarri 301
car type : sports car
Current Element :supercars
company : Lamborgini
car name : Lamborgini 001
car type :
car name : Lamborgini 002
car type :
car name : Lamborgini 003
car type :
डेमो उदाहरण
यहाँ XML हम बनाने की जरूरत है -
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars><supercars company = "Ferrari">
<carname type = "formula one">Ferrari 101</carname>
<carname type = "sports">Ferrari 202</carname>
</supercars></cars>
डेमो उदाहरण
CreateXmlFileDemo.java
package com.tutorialspoint.xml;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.DocumentBuilder;
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.Attr;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import java.io.File;
public class CreateXmlFileDemo {
public static void main(String argv[]) {
try {
DocumentBuilderFactory dbFactory =
DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder =
dbFactory.newDocumentBuilder();
Document doc = dBuilder.newDocument();
// root element
Element rootElement = doc.createElement("cars");
doc.appendChild(rootElement);
// supercars element
Element supercar = doc.createElement("supercars");
rootElement.appendChild(supercar);
// setting attribute to element
Attr attr = doc.createAttribute("company");
attr.setValue("Ferrari");
supercar.setAttributeNode(attr);
// carname element
Element carname = doc.createElement("carname");
Attr attrType = doc.createAttribute("type");
attrType.setValue("formula one");
carname.setAttributeNode(attrType);
carname.appendChild(
doc.createTextNode("Ferrari 101"));
supercar.appendChild(carname);
Element carname1 = doc.createElement("carname");
Attr attrType1 = doc.createAttribute("type");
attrType1.setValue("sports");
carname1.setAttributeNode(attrType1);
carname1.appendChild(
doc.createTextNode("Ferrari 202"));
supercar.appendChild(carname1);
// write the content into xml file
TransformerFactory transformerFactory =
TransformerFactory.newInstance();
Transformer transformer =
transformerFactory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result =
new StreamResult(new File("C:\\cars.xml"));
transformer.transform(source, result);
// Output to console for testing
StreamResult consoleResult =
new StreamResult(System.out);
transformer.transform(source, consoleResult);
} catch (Exception e) {
e.printStackTrace();
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars><supercars company = "Ferrari">
<carname type = "formula one">Ferrari 101</carname>
<carname type = "sports">Ferrari 202</carname>
</supercars></cars>
डेमो उदाहरण
यहाँ इनपुट xml फ़ाइल है जिसे हमें संशोधित करने की आवश्यकता है -
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars>
<supercars company = "Ferrari">
<carname type = "formula one">Ferrari 101</carname>
<carname type = "sports">Ferrari 202</carname>
</supercars>
<luxurycars company = "Benteley">
<carname>Benteley 1</carname>
<carname>Benteley 2</carname>
<carname>Benteley 3</carname>
</luxurycars>
</cars>
डेमो उदाहरण
ModifyXmlFileDemo.java
package com.tutorialspoint.xml;
import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
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.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
public class ModifyXmlFileDemo {
public static void main(String argv[]) {
try {
File inputFile = new File("input.txt");
DocumentBuilderFactory docFactory =
DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder =
docFactory.newDocumentBuilder();
Document doc = docBuilder.parse(inputFile);
Node cars = doc.getFirstChild();
Node supercar = doc.getElementsByTagName("supercars").item(0);
// update supercar attribute
NamedNodeMap attr = supercar.getAttributes();
Node nodeAttr = attr.getNamedItem("company");
nodeAttr.setTextContent("Lamborigini");
// loop the supercar child node
NodeList list = supercar.getChildNodes();
for (int temp = 0; temp < list.getLength(); temp++) {
Node node = list.item(temp);
if (node.getNodeType() == Node.ELEMENT_NODE) {
Element eElement = (Element) node;
if ("carname".equals(eElement.getNodeName())){
if("Ferrari 101".equals(eElement.getTextContent())){
eElement.setTextContent("Lamborigini 001");
}
if("Ferrari 202".equals(eElement.getTextContent()))
eElement.setTextContent("Lamborigini 002");
}
}
}
NodeList childNodes = cars.getChildNodes();
for(int count = 0; count < childNodes.getLength(); count++){
Node node = childNodes.item(count);
if("luxurycars".equals(node.getNodeName()))
cars.removeChild(node);
}
// write the content on console
TransformerFactory transformerFactory =
TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
DOMSource source = new DOMSource(doc);
System.out.println("-----------Modified File-----------");
StreamResult consoleResult = new StreamResult(System.out);
transformer.transform(source, consoleResult);
} catch (Exception e) {
e.printStackTrace();
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
-----------Modified File-----------
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars>
<supercars company = "Lamborigini">
<carname type = "formula one">Lamborigini 001</carname>
<carname type = "sports">Lamborigini 002</carname>
</supercars></cars>
SAX (XML के लिए सरल एपीआई) xml दस्तावेज़ों के लिए एक इवेंट-आधारित पार्सर है। DOM पार्सर के विपरीत, SAX पार्सर कोई पार्स ट्री नहीं बनाता है। SAX XML के लिए एक स्ट्रीमिंग इंटरफ़ेस है, जिसका अर्थ है कि SAX का उपयोग करने वाले अनुप्रयोगों को संसाधित किए जा रहे XML दस्तावेज़ के बारे में ईवेंट सूचनाएँ प्राप्त होती हैं - एक तत्व, और विशेषता, जो दस्तावेज़ के शीर्ष पर शुरू होने वाले क्रमिक समय में, और समापन के साथ समाप्त होता है। जड़ तत्व।
ऊपर से नीचे तक एक XML दस्तावेज़ पढ़ता है, एक अच्छी तरह से गठित XML दस्तावेज़ बनाने वाले टोकन को पहचानता है।
टोकन उसी क्रम में संसाधित किए जाते हैं जैसे वे दस्तावेज़ में दिखाई देते हैं।
एप्लिकेशन प्रोग्राम की रिपोर्ट करता है, टोकन की प्रकृति जो पार्सर का सामना करती है, जैसा कि वे होते हैं।
एप्लिकेशन प्रोग्राम एक "ईवेंट" हैंडलर प्रदान करता है जिसे पार्सर के साथ पंजीकृत होना चाहिए।
जैसे ही टोकन की पहचान की जाती है, हैंडलर में कॉलबैक विधियों को प्रासंगिक जानकारी के साथ लागू किया जाता है।
कब इस्तेमाल करें?
जब आपको SAX पार्सर का उपयोग करना चाहिए -
आप XML डॉक्युमेंट को ऊपर से नीचे तक लीनियर फैशन में प्रोसेस कर सकते हैं।
दस्तावेज़ को गहराई से नेस्टेड नहीं किया गया है।
आप एक बहुत बड़े XML डॉक्यूमेंट को संसाधित कर रहे हैं जिसका DOM ट्री बहुत मेमोरी की खपत करेगा। एक्सएमएल के एक बाइट का प्रतिनिधित्व करने के लिए विशिष्ट डोम कार्यान्वयन दस बाइट्स मेमोरी का उपयोग करते हैं।
हल की जाने वाली समस्या में XML दस्तावेज़ का केवल एक हिस्सा शामिल है।
डेटा जैसे ही पार्सर द्वारा देखा जाता है, तो SAX एक XML दस्तावेज़ के लिए अच्छी तरह से काम करता है जो एक स्ट्रीम पर आता है।
SAX के नुकसान
किसी XML दस्तावेज़ में हमारी कोई यादृच्छिक पहुँच नहीं है क्योंकि यह एक अग्रेषित तरीके से संसाधित होता है।
यदि आपको डेटा को ट्रैक करने की आवश्यकता है तो पार्सर ने वस्तुओं के क्रम को देखा या बदल दिया है, तो आपको कोड लिखना होगा और डेटा को अपने आप स्टोर करना होगा।
ContentHandler इंटरफ़ेस
यह इंटरफ़ेस कॉलबैक विधियों को निर्दिष्ट करता है जो SAX पार्सर XML दस्तावेज़ के घटकों के एक एप्लिकेशन प्रोग्राम को सूचित करने के लिए उपयोग करता है जो उसने देखा है।
void startDocument() - एक दस्तावेज की शुरुआत में कहा जाता है।
void endDocument() - एक दस्तावेज की शुरुआत में कहा जाता है।
void startElement(String uri, String localName, String qName, Attributes atts) - एक तत्व की शुरुआत में कहा जाता है।
void endElement(String uri, String localName,String qName) - एक तत्व के अंत में कहा जाता है।
void characters(char[] ch, int start, int length) - चरित्र डेटा का सामना होने पर कॉल किया जाता है।
void ignorableWhitespace( char[] ch, int start, int length) - जब DTD मौजूद होता है और आग्नेय व्हाट्सएप का सामना किया जाता है।
void processingInstruction(String target, String data) - जब एक प्रसंस्करण निर्देश को मान्यता दी जाती है।
void setDocumentLocator(Locator locator)) - एक लोकेटर प्रदान करता है जिसका उपयोग दस्तावेज़ में पदों की पहचान करने के लिए किया जा सकता है।
void skippedEntity(String name) - एक अनसुलझे इकाई का सामना होने पर बुलाया जाता है।
void startPrefixMapping(String prefix, String uri) - नया नामस्थान मानचित्रण परिभाषित होने पर कॉल किया जाता है।
void endPrefixMapping(String prefix) - जब एक नेमस्पेस परिभाषा समाप्त हो जाती है तो कॉल किया जाता है।
विशेषताएँ इंटरफ़ेस
यह इंटरफ़ेस किसी तत्व से जुड़ी विशेषताओं को संसाधित करने के तरीकों को निर्दिष्ट करता है।
int getLength() - विशेषताओं की संख्या लौटाता है।
String getQName(int index)
String getValue(int index)
String getValue(String qname)
डेमो उदाहरण
यहाँ इनपुट xml फ़ाइल है जिसे हमें पार्स करने की आवश्यकता है -
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
UserHandler.java
package com.tutorialspoint.xml;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class UserHandler extends DefaultHandler {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
@Override
public void startElement(String uri,
String localName, String qName, Attributes attributes) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
String rollNo = attributes.getValue("rollno");
System.out.println("Roll No : " + rollNo);
} else if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
}
@Override
public void endElement(String uri,
String localName, String qName) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
System.out.println("End Element :" + qName);
}
}
@Override
public void characters(char ch[], int start, int length) throws SAXException {
if (bFirstName) {
System.out.println("First Name: " + new String(ch, start, length));
bFirstName = false;
} else if (bLastName) {
System.out.println("Last Name: " + new String(ch, start, length));
bLastName = false;
} else if (bNickName) {
System.out.println("Nick Name: " + new String(ch, start, length));
bNickName = false;
} else if (bMarks) {
System.out.println("Marks: " + new String(ch, start, length));
bMarks = false;
}
}
}
SAXParserDemo.java
package com.tutorialspoint.xml;
import java.io.File;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class SAXParserDemo {
public static void main(String[] args){
try {
File inputFile = new File("input.txt");
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser = factory.newSAXParser();
UserHandler userhandler = new UserHandler();
saxParser.parse(inputFile, userhandler);
} catch (Exception e) {
e.printStackTrace();
}
}
}
class UserHandler extends DefaultHandler {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
@Override
public void startElement(String uri,
String localName, String qName, Attributes attributes) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
String rollNo = attributes.getValue("rollno");
System.out.println("Roll No : " + rollNo);
} else if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
}
@Override
public void endElement(String uri,
String localName, String qName) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
System.out.println("End Element :" + qName);
}
}
@Override
public void characters(char ch[], int start, int length) throws SAXException {
if (bFirstName) {
System.out.println("First Name: " + new String(ch, start, length));
bFirstName = false;
} else if (bLastName) {
System.out.println("Last Name: " + new String(ch, start, length));
bLastName = false;
} else if (bNickName) {
System.out.println("Nick Name: " + new String(ch, start, length));
bNickName = false;
} else if (bMarks) {
System.out.println("Marks: " + new String(ch, start, length));
bMarks = false;
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
Roll No : 393
First Name: Dinkar
Last Name: Kad
Nick Name: Dinkar
Marks: 85
End Element :student
Roll No : 493
First Name: Vineet
Last Name: Gupta
Nick Name: Vinni
Marks: 95
End Element :student
Roll No : 593
First Name: Jasvir
Last Name: Singh
Nick Name: Jazz
Marks: 90
End Element :student
डेमो उदाहरण
यहाँ इनपुट टेक्स्ट फ़ाइल है जिसे हमें रोल नंबर: 393 के लिए क्वेरी करने की आवश्यकता है -
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
UserHandler.java
package com.tutorialspoint.xml;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class UserHandler extends DefaultHandler {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
String rollNo = null;
@Override
public void startElement(String uri,
String localName, String qName, Attributes attributes) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
rollNo = attributes.getValue("rollno");
}
if(("393").equals(rollNo) && qName.equalsIgnoreCase("student")){
System.out.println("Start Element :" + qName);
}
if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
}
@Override
public void endElement(String uri, String localName, String qName) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
if(("393").equals(rollNo)
&& qName.equalsIgnoreCase("student"))
System.out.println("End Element :" + qName);
}
}
@Override
public void characters(char ch[], int start, int length) throws SAXException {
if (bFirstName && ("393").equals(rollNo)) {
//age element, set Employee age
System.out.println("First Name: " + new String(ch, start, length));
bFirstName = false;
} else if (bLastName && ("393").equals(rollNo)) {
System.out.println("Last Name: " + new String(ch, start, length));
bLastName = false;
} else if (bNickName && ("393").equals(rollNo)) {
System.out.println("Nick Name: " + new String(ch, start, length));
bNickName = false;
} else if (bMarks && ("393").equals(rollNo)) {
System.out.println("Marks: " + new String(ch, start, length));
bMarks = false;
}
}
}
SAXQueryDemo.java
package com.tutorialspoint.xml;
import java.io.File;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class SAXQueryDemo {
public static void main(String[] args){
try {
File inputFile = new File("input.txt");
SAXParserFactory factory = SAXParserFactory.newInstance();
SAXParser saxParser = factory.newSAXParser();
UserHandler userhandler = new UserHandler();
saxParser.parse(inputFile, userhandler);
} catch (Exception e) {
e.printStackTrace();
}
}
}
class UserHandler extends DefaultHandler {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
String rollNo = null;
@Override
public void startElement(String uri,
String localName, String qName, Attributes attributes) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
rollNo = attributes.getValue("rollno");
}
if(("393").equals(rollNo) &&
qName.equalsIgnoreCase("student")){
System.out.println("Start Element :" + qName);
}
if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
}
@Override
public void endElement(String uri,
String localName, String qName) throws SAXException {
if (qName.equalsIgnoreCase("student")) {
if(("393").equals(rollNo)
&& qName.equalsIgnoreCase("student"))
System.out.println("End Element :" + qName);
}
}
@Override
public void characters(char ch[], int start, int length) throws SAXException {
if (bFirstName && ("393").equals(rollNo)) {
//age element, set Employee age
System.out.println("First Name: " + new String(ch, start, length));
bFirstName = false;
} else if (bLastName && ("393").equals(rollNo)) {
System.out.println("Last Name: " + new String(ch, start, length));
bLastName = false;
} else if (bNickName && ("393").equals(rollNo)) {
System.out.println("Nick Name: " + new String(ch, start, length));
bNickName = false;
} else if (bMarks && ("393").equals(rollNo)) {
System.out.println("Marks: " + new String(ch, start, length));
bMarks = false;
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
Start Element :student
First Name: Dinkar
Last Name: Kad
Nick Name: Dinkar
Marks: 85
End Element :student
SAX पार्सर के उपयोग से XML बनाने के लिए Stax parser का उपयोग करना बेहतर है। कृपया उसी के लिए जावा Stax Parser अनुभाग देखें।
डेमो उदाहरण
यहाँ इनपुट xml फ़ाइल है जिसे हमें संशोधित करके संशोधित करना होगा <Result>Pass<Result/> के अंत में </marks> tag।
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
SAXModifyDemo.java
package com.tutorialspoint.xml;
import java.io.*;
import org.xml.sax.*;
import javax.xml.parsers.*;
import org.xml.sax.helpers.DefaultHandler;
public class SAXModifyDemo extends DefaultHandler {
static String displayText[] = new String[1000];
static int numberLines = 0;
static String indentation = "";
public static void main(String args[]) {
try {
File inputFile = new File("input.txt");
SAXParserFactory factory =
SAXParserFactory.newInstance();
SAXModifyDemo obj = new SAXModifyDemo();
obj.childLoop(inputFile);
FileWriter filewriter = new FileWriter("newfile.xml");
for(int loopIndex = 0; loopIndex < numberLines; loopIndex++){
filewriter.write(displayText[loopIndex].toCharArray());
filewriter.write('\n');
System.out.println(displayText[loopIndex].toString());
}
filewriter.close();
} catch (Exception e) {
e.printStackTrace(System.err);
}
}
public void childLoop(File input){
DefaultHandler handler = this;
SAXParserFactory factory = SAXParserFactory.newInstance();
try {
SAXParser saxParser = factory.newSAXParser();
saxParser.parse(input, handler);
} catch (Throwable t) {}
}
public void startDocument() {
displayText[numberLines] = indentation;
displayText[numberLines] += "<?xml version=\"1.0\" encoding=\""+
"UTF-8" + "\"?>";
numberLines++;
}
public void processingInstruction(String target, String data) {
displayText[numberLines] = indentation;
displayText[numberLines] += "<?";
displayText[numberLines] += target;
if (data != null && data.length() > 0) {
displayText[numberLines] += ' ';
displayText[numberLines] += data;
}
displayText[numberLines] += "?>";
numberLines++;
}
public void startElement(String uri, String localName,
String qualifiedName, Attributes attributes) {
displayText[numberLines] = indentation;
indentation += " ";
displayText[numberLines] += '<';
displayText[numberLines] += qualifiedName;
if (attributes != null) {
int numberAttributes = attributes.getLength();
for (int loopIndex = 0; loopIndex < numberAttributes;
loopIndex++){
displayText[numberLines] += ' ';
displayText[numberLines] += attributes.getQName(loopIndex);
displayText[numberLines] += "=\"";
displayText[numberLines] += attributes.getValue(loopIndex);
displayText[numberLines] += '"';
}
}
displayText[numberLines] += '>';
numberLines++;
}
public void characters(char characters[], int start, int length) {
String characterData = (new String(characters, start, length)).trim();
if(characterData.indexOf("\n") < 0 && characterData.length() > 0) {
displayText[numberLines] = indentation;
displayText[numberLines] += characterData;
numberLines++;
}
}
public void endElement(String uri, String localName, String qualifiedName) {
indentation = indentation.substring(0, indentation.length() - 4);
displayText[numberLines] = indentation;
displayText[numberLines] += "</";
displayText[numberLines] += qualifiedName;
displayText[numberLines] += '>';
numberLines++;
if (qualifiedName.equals("marks")) {
startElement("", "Result", "Result", null);
characters("Pass".toCharArray(), 0, "Pass".length());
endElement("", "Result", "Result");
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
<?xml version = "1.0" encoding = "UTF-8"?>
<class>
<student rollno = "393">
<firstname>
Dinkar
</firstname>
<lastname>
Kad
</lastname>
<nickname>
Dinkar
</nickname>
<marks>
85
</marks>
<Result>
Pass
</Result>
</student>
<student rollno = "493">
<firstname>
Vineet
</firstname>
<lastname>
Gupta
</lastname>
<nickname>
Vinni
</nickname>
<marks>
95
</marks>
<Result>
Pass
</Result>
</student>
<student rollno = "593">
<firstname>
Jasvir
</firstname>
<lastname>
Singh
</lastname>
<nickname>
Jazz
</nickname>
<marks>
90
</marks>
<Result>
Pass
</Result>
</student>
</class>
Stax, XML दस्तावेज़ को उसी तरह से पार्स करने के लिए एक जावा आधारित एपीआई है, जैसा SAX पार्सर करता है। लेकिन दो एपीआई के बीच अंतर के दो प्रमुख बिंदु हैं -
StAX एक PULL API है जबकि, SAX एक PUSH API है। इसका मतलब है कि Stax parser के मामले में, क्लाइंट एप्लिकेशन को जब भी आवश्यकता होती है, तो XML से जानकारी प्राप्त करने के लिए Stax parser से पूछने की आवश्यकता होती है, लेकिन SAX पार्सर के मामले में, क्लाइंट एप्लिकेशन को जानकारी प्राप्त करने की आवश्यकता होती है जब SAX पार्सर क्लाइंट को उस सूचना को सूचित करता है। उपलब्ध है।
Stax API XML डॉक्यूमेंट लिखने के साथ-साथ पढ़ भी सकते हैं। SAX API का उपयोग करके, xml को केवल पढ़ा जा सकता है।
निम्नलिखित StAX एपीआई की विशेषताएं हैं -
ऊपर से नीचे तक एक XML दस्तावेज़ पढ़ता है, एक अच्छी तरह से गठित XML दस्तावेज़ बनाने वाले टोकन को पहचानता है।
टोकन उसी क्रम में संसाधित किए जाते हैं जैसे वे दस्तावेज़ में दिखाई देते हैं।
टोकरों की प्रकृति पर अनुप्रयोग कार्यक्रम की रिपोर्ट करता है जो पार्सर का सामना करते हैं।
एप्लिकेशन प्रोग्राम एक "ईवेंट" रीडर प्रदान करता है जो एक पुनरावृत्त के रूप में कार्य करता है और आवश्यक जानकारी प्राप्त करने के लिए इवेंट पर पुनरावृत्त करता है। उपलब्ध एक और पाठक "कर्सर" रीडर है जो xml नोड्स के लिए एक सूचक के रूप में कार्य करता है।
जैसा कि घटनाओं की पहचान की जाती है, xml तत्वों को इवेंट ऑब्जेक्ट से पुनर्प्राप्त किया जा सकता है और आगे संसाधित किया जा सकता है।
कब इस्तेमाल करें?
जब आपको Stax parser का उपयोग करना चाहिए -
आप XML डॉक्युमेंट को ऊपर से नीचे तक लीनियर फैशन में प्रोसेस कर सकते हैं।
दस्तावेज़ को गहराई से नेस्टेड नहीं किया गया है।
आप एक बहुत बड़े XML दस्तावेज़ डोम ट्री का प्रसंस्करण कर रहे हैं, जो बहुत अधिक मेमोरी का उपभोग करेगा। एक्सएमएल के एक बाइट का प्रतिनिधित्व करने के लिए विशिष्ट डोम कार्यान्वयन दस बाइट्स मेमोरी का उपयोग करते हैं।
हल की जाने वाली समस्या में XML दस्तावेज़ का केवल एक हिस्सा शामिल है।
डेटा जैसे ही पार्सर द्वारा देखा जाता है, तो Stax एक XML दस्तावेज़ के लिए अच्छी तरह से काम करता है जो एक स्ट्रीम पर आता है।
SAX के नुकसान
XML दस्तावेज़ के लिए हमारे पास कोई यादृच्छिक पहुँच नहीं है क्योंकि यह केवल-अग्रेषित तरीके से संसाधित होता है।
यदि आपको डेटा को ट्रैक करने की आवश्यकता है तो पार्सर ने वस्तुओं के क्रम को देखा या बदल दिया है, तो आपको कोड लिखना होगा और डेटा को अपने आप स्टोर करना होगा।
XMLEventReader क्लास
यह वर्ग उन घटनाओं का पुनरावृत्ति प्रदान करता है जिनका उपयोग XML दस्तावेज़ को पार्स करते समय होने वाली घटनाओं पर पुनरावृति करने के लिए किया जा सकता है
StartElement asStartElement() - तत्व के मूल्य और विशेषताओं को पुनः प्राप्त करने के लिए उपयोग किया जाता है।
EndElement asEndElement() - एक तत्व के अंत में कहा जाता है।
Characters asCharacters() - सीडीएटीए, व्हॉट्सएप आदि जैसे पात्रों को प्राप्त करने के लिए इस्तेमाल किया जा सकता है।
एक्सलेवेंटवर्टर क्लास
यह इंटरफ़ेस ईवेंट बनाने के लिए विधियाँ निर्दिष्ट करता है।
add(Event event) - XML वाले तत्वों को जोड़ता है।
XMLStreamReader क्लास
यह वर्ग उन घटनाओं का पुनरावृत्ति प्रदान करता है जिनका उपयोग XML दस्तावेज़ को पार्स करते समय होने वाली घटनाओं पर पुनरावृति करने के लिए किया जा सकता है
int next() - अगली घटना को पुनः प्राप्त करने के लिए उपयोग किया जाता है।
boolean hasNext() - आगे की घटनाओं की जाँच करने के लिए प्रयोग किया जाता है कि मौजूद है या नहीं
String getText() - किसी तत्व का पाठ प्राप्त करने के लिए उपयोग किया जाता है
String getLocalName() - एक तत्व का नाम पाने के लिए उपयोग किया जाता है
XMLStreamWriter क्लास
यह इंटरफ़ेस ईवेंट बनाने के लिए विधियाँ निर्दिष्ट करता है।
writeStartElement(String localName) - किसी दिए गए नाम का प्रारंभ तत्व जोड़ता है।
writeEndElement(String localName) - दिए गए नाम के तत्व को जोड़ता है।
writeAttribute(String localName, String value) - एक तत्व को लिखता है।
डेमो उदाहरण
यहाँ इनपुट xml फ़ाइल है जिसे हमें पार्स करने की आवश्यकता है -
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
StAXParserDemo.java
package com.tutorialspoint.xml;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.util.Iterator;
import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamConstants;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.events.Attribute;
import javax.xml.stream.events.Characters;
import javax.xml.stream.events.EndElement;
import javax.xml.stream.events.StartElement;
import javax.xml.stream.events.XMLEvent;
public class StAXParserDemo {
public static void main(String[] args) {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
try {
XMLInputFactory factory = XMLInputFactory.newInstance();
XMLEventReader eventReader =
factory.createXMLEventReader(new FileReader("input.txt"));
while(eventReader.hasNext()){
XMLEvent event = eventReader.nextEvent();
switch(event.getEventType()){
case XMLStreamConstants.START_ELEMENT:
StartElement startElement = event.asStartElement();
String qName = startElement.getName().getLocalPart();
if (qName.equalsIgnoreCase("student")) {
System.out.println("Start Element : student");
Iterator<Attribute> attributes = startElement.getAttributes();
String rollNo = attributes.next().getValue();
System.out.println("Roll No : " + rollNo);
} else if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
break;
case XMLStreamConstants.CHARACTERS:
Characters characters = event.asCharacters();
if(bFirstName){
System.out.println("First Name: " + characters.getData());
bFirstName = false;
}
if(bLastName){
System.out.println("Last Name: " + characters.getData());
bLastName = false;
}
if(bNickName){
System.out.println("Nick Name: " + characters.getData());
bNickName = false;
}
if(bMarks){
System.out.println("Marks: " + characters.getData());
bMarks = false;
}
break;
case XMLStreamConstants.END_ELEMENT:
EndElement endElement = event.asEndElement();
if(endElement.getName().getLocalPart().equalsIgnoreCase("student")){
System.out.println("End Element : student");
System.out.println();
}
break;
}
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (XMLStreamException e) {
e.printStackTrace();
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
Start Element : student
Roll No : 393
First Name: Dinkar
Last Name: Kad
Nick Name: Dinkar
Marks: 85
End Element : student
Start Element : student
Roll No : 493
First Name: Vineet
Last Name: Gupta
Nick Name: Vinni
Marks: 95
End Element : student
Start Element : student
Roll No : 593
First Name: Jasvir
Last Name: Singh
Nick Name: Jazz
Marks: 90
End Element : student
डेमो उदाहरण
यहाँ इनपुट xml फ़ाइल है जिसे हमें पार्स करने की आवश्यकता है -
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
StAXParserDemo.java
package com.tutorialspoint.xml;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.util.Iterator;
import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamConstants;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.events.Attribute;
import javax.xml.stream.events.Characters;
import javax.xml.stream.events.EndElement;
import javax.xml.stream.events.StartElement;
import javax.xml.stream.events.XMLEvent;
public class StAXQueryDemo {
public static void main(String[] args) {
boolean bFirstName = false;
boolean bLastName = false;
boolean bNickName = false;
boolean bMarks = false;
boolean isRequestRollNo = false;
try {
XMLInputFactory factory = XMLInputFactory.newInstance();
XMLEventReader eventReader = factory.createXMLEventReader(
new FileReader("input.txt"));
String requestedRollNo = "393";
while(eventReader.hasNext()){
XMLEvent event = eventReader.nextEvent();
switch(event.getEventType()){
case XMLStreamConstants.START_ELEMENT:
StartElement startElement = event.asStartElement();
String qName = startElement.getName().getLocalPart();
if (qName.equalsIgnoreCase("student")) {
Iterator<Attribute> attributes = startElement.getAttributes();
String rollNo = attributes.next().getValue();
if(rollNo.equalsIgnoreCase(requestedRollNo)){
System.out.println("Start Element : student");
System.out.println("Roll No : " + rollNo);
isRequestRollNo = true;
}
} else if (qName.equalsIgnoreCase("firstname")) {
bFirstName = true;
} else if (qName.equalsIgnoreCase("lastname")) {
bLastName = true;
} else if (qName.equalsIgnoreCase("nickname")) {
bNickName = true;
} else if (qName.equalsIgnoreCase("marks")) {
bMarks = true;
}
break;
case XMLStreamConstants.CHARACTERS:
Characters characters = event.asCharacters();
if(bFirstName && isRequestRollNo){
System.out.println("First Name: " + characters.getData());
bFirstName = false;
}
if(bLastName && isRequestRollNo){
System.out.println("Last Name: " + characters.getData());
bLastName = false;
}
if(bNickName && isRequestRollNo){
System.out.println("Nick Name: " + characters.getData());
bNickName = false;
}
if(bMarks && isRequestRollNo){
System.out.println("Marks: " + characters.getData());
bMarks = false;
}
break;
case XMLStreamConstants.END_ELEMENT:
EndElement endElement = event.asEndElement();
if(endElement.getName().getLocalPart().equalsIgnoreCase("student") && isRequestRollNo){
System.out.println("End Element : student");
System.out.println();
isRequestRollNo = false;
}
break;
}
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (XMLStreamException e) {
e.printStackTrace();
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
Start Element : student
Roll No : 393
First Name: Dinkar
Last Name: Kad
Nick Name: Dinkar
Marks: 85
End Element : student
डेमो उदाहरण
Here is the XML we need to create −
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars><supercars company = "Ferrari">
<carname type = "formula one">Ferrari 101</carname>
<carname type = "sports">Ferrari 202</carname>
</supercars></cars>
डेमो उदाहरण
StAXCreateXMLDemo.java
package com.tutorialspoint.xml;
import java.io.IOException;
import java.io.StringWriter;
import javax.xml.stream.XMLOutputFactory;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamWriter;
public class StAXCreateXMLDemo {
public static void main(String[] args) {
try {
StringWriter stringWriter = new StringWriter();
XMLOutputFactory xMLOutputFactory = XMLOutputFactory.newInstance();
XMLStreamWriter xMLStreamWriter = xMLOutputFactory.createXMLStreamWriter(stringWriter);
xMLStreamWriter.writeStartDocument();
xMLStreamWriter.writeStartElement("cars");
xMLStreamWriter.writeStartElement("supercars");
xMLStreamWriter.writeAttribute("company", "Ferrari");
xMLStreamWriter.writeStartElement("carname");
xMLStreamWriter.writeAttribute("type", "formula one");
xMLStreamWriter.writeCharacters("Ferrari 101");
xMLStreamWriter.writeEndElement();
xMLStreamWriter.writeStartElement("carname");
xMLStreamWriter.writeAttribute("type", "sports");
xMLStreamWriter.writeCharacters("Ferrari 202");
xMLStreamWriter.writeEndElement();
xMLStreamWriter.writeEndElement();
xMLStreamWriter.writeEndDocument();
xMLStreamWriter.flush();
xMLStreamWriter.close();
String xmlString = stringWriter.getBuffer().toString();
stringWriter.close();
System.out.println(xmlString);
} catch (XMLStreamException e) {
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
<?xml version = "1.0" encoding = "UTF-8" standalone = "no"?>
<cars><supercars company = "Ferrari">
<carname type = "formula one">Ferrari 101</carname>
<carname type = "sports">Ferrari 202</carname>
</supercars></cars>
डेमो उदाहरण
इस उदाहरण को चलाने के लिए, आपको अपने आवेदन के वर्गपाठ में jdom.jar रखना चाहिए। Jdom-2.0.5.zip डाउनलोड करें।
यहाँ XML हम संशोधित करने की आवश्यकता है -
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
डेमो उदाहरण
StAXModifyDemo.java
package com.tutorialspoint.xml;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamConstants;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.events.Attribute;
import javax.xml.stream.events.StartElement;
import javax.xml.stream.events.XMLEvent;
import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.JDOMException;
import org.jdom2.input.SAXBuilder;
import org.jdom2.output.Format;
import org.jdom2.output.XMLOutputter;
public class StAXModifyDemo {
public static void main(String[] args) {
try {
XMLInputFactory factory = XMLInputFactory.newInstance();
XMLEventReader eventReader =
factory.createXMLEventReader(
new FileReader("input.txt"));
SAXBuilder saxBuilder = new SAXBuilder();
Document document = saxBuilder.build(new File("input.txt"));
Element rootElement = document.getRootElement();
List<Element> studentElements = rootElement.getChildren("student");
while(eventReader.hasNext()){
XMLEvent event = eventReader.nextEvent();
switch(event.getEventType()){
case XMLStreamConstants.START_ELEMENT:
StartElement startElement = event.asStartElement();
String qName = startElement.getName().getLocalPart();
if (qName.equalsIgnoreCase("student")) {
Iterator<Attribute> attributes = startElement.getAttributes();
String rollNo = attributes.next().getValue();
if(rollNo.equalsIgnoreCase("393")){
//get the student with roll no 393
for(int i=0;i < studentElements.size();i++){
Element studentElement = studentElements.get(i);
if(studentElement.getAttribute("rollno").getValue().equalsIgnoreCase("393")){
studentElement.removeChild("marks");
studentElement.addContent(new Element("marks").setText("80"));
}
}
}
}
break;
}
}
XMLOutputter xmlOutput = new XMLOutputter();
// display xml
xmlOutput.setFormat(Format.getPrettyFormat());
xmlOutput.output(document, System.out);
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (XMLStreamException e) {
e.printStackTrace();
} catch (JDOMException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
उपरोक्त कार्यक्रम निम्नलिखित परिणाम उत्पन्न करेगा -
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>80</marks>
</student>
<student rollno = "493">
<firstname>Vineet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>