Ich versuche, diesen Prozess zu automatisieren.
Ich habe einen Link zu dieser XML-Datei. Sie hat viele Parameter, aber mich interessieren nur drei davon. Ich möchte diese drei Parameter verwenden und automatisch eine neue XML-Datei mit unterschiedlichen Tag-Namen erstellen.
siehe Screenshot.
Original-XML-Datei.XML-Datei
Mich interessieren nur alle //item/image"
, //item/source/file_details/file
, und //item/title
.
Wie kann ich automatisch eine weitere XML-Datei erstellen und alle diese Parameter mit unterschiedlichen Metanamen dort erhalten?
Ich habe versucht, es importxml
in eine Google-Tabelle zu importieren, weiß aber nicht, wie ich daraus XML erstellen kann.
Das Endergebnis sollte so aussehen. `http://blog.defaultroute.com/2011/01/04/building-a-roku-channel-part-2/
Danke
Antwort1
Sie könnten dazu eine Java-Anwendung schreiben.
Um die Daten auszulesen benötigen Sie zB:
File fXmlFile = new File(fileName);
DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
Document doc = dBuilder.parse(fXmlFile);
doc.getDocumentElement().normalize();
NodeList playlists = doc.getElementsByTagName("playlist"); // Get all Nodes named 'playlist'
if(playlists != null && playlists.getLength() > 0){
for (int temp = 0; temp < playlists.getLength(); temp++) { // Iterate through all 'playlists'
if(playlists.item(temp).getNodeType() == Node.ELEMENT_NODE){ //Check if they are Elements (just to be sure)
Element playlist = (Element) playlists.item(temp); // Cast to Element
NodeList items = playlist.getElementsByTagName("item"); // Get Nodes named 'item' in 'playlist'
for (int temp1 = 0; temp1 < items.getLength(); temp1++) { // Iterate through all items
if(items.item(temp1).getNodeType() == Node.ELEMENT_NODE){
Element item = (Element) items.item(temp1);
NodeList imgs = item.getElementsByTagName("image");
Node img = imgs.item(0); // We suppose there is only one image-node in the item-node
if(img.getNodeType() == Node.ELEMENT_NODE){
Element image = (Element) img;
String imgUrl = image.getTextContent(); // Get the textContent of image --> Store it in an Array(List) etc...
}
}
}
}
}
}
Natürlich müssen Sie dasselbe auch für die anderen Knoten tun.
Und schreiben Sie es mit dem DocumentBuilder in eine XML-Datei zurück.
DocumentBuilderFactory docFactory = DocumentBuilderFactory.newInstance();
DocumentBuilder docBuilder = docFactory.newDocumentBuilder();
Document doc = docBuilder.newDocument();
Element rootElement = doc.createElement("playlist");
doc.appendChild(rootElement);
Element item = doc.createElement("item");
rootElement.appendChild(item);
Element image = doc.createElement("image");
item.appendChild(image);
image.appendChild(doc.createTextNode("HERE YOUR ImgURL "));
TransformerFactory transformerFactory = TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
DOMSource source = new DOMSource(doc);
StreamResult result = new StreamResult(new File(fileName));
transformer.transform(source, result);
Hoffe, das hilft ein wenig.