<?xml version="1.0" encoding="UTF-16"?>
<ABC>
<END />
<Tables>
<START>
<row>
<id>111</id>
<name>abc</name>
<deptId>1</deptId>
</row>
<row>
<id>112</id>
<name>abc1</name>
<deptId>1</deptId>
</row>
<row>
<id>113</id>
<name>abc3</name>
<deptId>1</deptId>
</row>
<row>
<id>222</id>
<name>def</name>
<deptId>2</deptId>
</row>
<row>
<id>333</id>
<name>pqr</name>
<deptId>2</deptId>
</row>
<row>
<id>444</id>
<name>xyz</name>
<deptId>2</deptId>
</row>
<row>
<id>555</id>
<name>lmn</name>
<deptId>3</deptId>
</row>
<row>
<id>555</id>
<name>lmn</name>
<deptId>3</deptId>
</row>
</START>
</Tables>
</ABC>
I have a xml with the above structure. I have to spilt the xml into 3 xmls based on the different deptId
.
I have to Split the xml into smaller one based on change in tag values. My elemement is deptId
whose values is been changes after some rows.
The all elements with same deptId
are in a sequence.
The required output is : Its good to have the xml name as the department id.
The first xml be with name 1.xml
:
<?xml version="1.0" encoding="UTF-16"?>
<ABC>
<END />
<Tables>
<START>
<row>
<id>111</id>
<name>abc</name>
<deptId>1</deptId>
</row>
<row>
<id>112</id>
<name>abc1</name>
<deptId>1</deptId>
</row>
<row>
<id>113</id>
<name>abc3</name>
<deptId>1</deptId>
</row>
</START>
</Tables>
</ABC>
The second xml with name 2.xml :
<?xml version="1.0" encoding="UTF-16"?>
<ABC>
<END />
<Tables>
<START>
<row>
<id>222</id>
<name>def</name>
<deptId>2</deptId>
</row>
<row>
<id>333</id>
<name>pqr</name>
<deptId>2</deptId>
</row>
<row>
<id>444</id>
<name>xyz</name>
<deptId>2</deptId>
</row>
</START>
</Tables>
</ABC>
The third xml with name 3.xml :
<?xml version="1.0" encoding="UTF-16"?>
<ABC>
<END />
<Tables>
<START>
<row>
<id>113</id>
<name>abc3</name>
<deptId>1</deptId>
</row>
</START>
</Tables>
</ABC>
I had tried with the StAXSource
option by referring couple of option
The option I have tried are by referring below links
Here is the sample piece of code that have been tried.
import java.io.File;
import java.io.FileReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamReader;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.stax.StAXSource;
import javax.xml.transform.stream.StreamResult;
public class Demo2 {
public static void main(String[] args) throws Exception {
XMLInputFactory xif = XMLInputFactory.newInstance();
XMLStreamReader streamReader = xif.createXMLStreamReader(new FileReader("D://SmallXmltoSplit.xml"));
streamReader.nextTag(); // Advance to next element
streamReader.nextTag();
streamReader.nextTag();
streamReader.nextTag();
streamReader.nextTag();
streamReader.nextTag();
TransformerFactory tf = TransformerFactory.newInstance();
Transformer t = tf.newTransformer();
String deptId = null;
File file = new File("D://test" + ".xml");
while (streamReader.hasNext()) {
if (streamReader.isStartElement()) {
if (streamReader.getLocalName().equals("deptId")) {
if (deptId == null) {
deptId = streamReader.getElementText();
file = new File("D://" + deptId + ".xml");
t.transform(new StAXSource(streamReader), new StreamResult(file));
} else if (deptId != streamReader.getElementText()) {
file = new File("D://" + deptId + ".xml");
t.transform(new StAXSource(streamReader), new StreamResult(file));
}
}
t.transform(new StAXSource(streamReader), new StreamResult(file));
}
streamReader.next();
}
}
}