1

Я пытаюсь автоматизировать этот процесс.

У меня есть ссылка на этот XML-файл. у него много параметров, но меня интересуют только 3 его параметра. Я хочу использовать эти 3 параметра и автоматически создавать новый XML-файл с разными именами тегов.

смотрите скриншот.

Оригинальный файл XML.XML-файл

Меня интересуют только все //item/image" , //item/source/file_details/file и //item/title .

Как я могу автоматически создать еще один XML-файл и получить все эти параметры с разными мета-именами?

Я пытался импортировать importxml в электронную таблицу Google, но не знаю, как создать из нее XML.

Конечный результат должен быть таким. ` http://blog.defaultroute.com/2011/01/04/building-a-roku-channel-part-2/

Спасибо

1 ответ1

1

Вы можете написать Java-приложение, чтобы добиться цели.

Например, чтобы прочитать нужные вам данные:

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...                                      
                            }               
                        }
                    }
                }
            }
        }

Конечно, вы должны сделать то же самое для других узлов.

И запишите его обратно в XML-файл, используя DocumentBuilder.

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);

Надеюсь это немного поможет.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .