Парсинг тэгов XML в Java с URL - PullRequest
       2

Парсинг тэгов XML в Java с URL

0 голосов
/ 05 ноября 2011

Я пытаюсь извлечь контент из тэгов xml из URL, но длина моего int numberOfDetails равна 0. Что я делаю не так?

// Отредактированный код

public String[] dumpTitles(String[] xmlFiles) {


        String[] elementsArray = null;
        try { 
            URL xmlContent = new URL("http://webdev4.matcmadison.edu/mab/AmazonXML/georgeEliot.xml");
            DocumentBuilder db = DocumentBuilderFactory.newInstance().newDocumentBuilder();
            Document doc = db.parse(new InputSource(xmlContent.openStream()));


            Toast.makeText(this, "xml file: " + xmlContent, 1000).show();

            NodeList detailsNodeList = doc.getElementsByTagName("Details");
            int numberOfDetails = detailsNodeList.getLength();
            String str = String.format("There are %d Details elements", numberOfDetails);
            Log.println(Log.DEBUG, TAG, str);
            Toast.makeText(this, "number of details: " + str, 1000).show();
            elementsArray = getElementByTagName("ProductName", numberOfDetails, detailsNodeList);
        }
        catch (Exception ex) {
            Log.println(Log.DEBUG, TAG, "XML Parsing failed: " + ex.getMessage());
        }

        return elementsArray;  

    }

  public String[] getElementByTagName(String detailTagName, int numberOfDetails, NodeList detailsNodeList) throws Exception {
      String[] elementsArray = null;
      ArrayList<String> elementsArrayList = new ArrayList<String>();
      Toast.makeText(this, "TEST2", 1000).show();
        for (int k = 0; k < numberOfDetails; k++) {
            Toast.makeText(this, "TEST3", 1000).show();
            Element nDetails = (Element)detailsNodeList.item(k);
            NodeList elementNodeList = ((Document) nDetails).getElementsByTagName(detailTagName);
            Node nodeName = elementNodeList.item(k);
            String nodeString = String.format("%s", nodeName);
            elementsArrayList.add(nodeString);
            elementsArray = elementsArrayList.toArray(elementsArray);
            Log.println(Log.DEBUG, TAG, nodeString);
            Toast.makeText(this, "TEST4", 1000).show();
            Toast.makeText(this, "ELEMENT" + elementsArray[0], 1000).show();

        }

        return elementsArray;
}

// Исходный код String xmlContent = "http://webdev4.matcmadison.edu/mab/AmazonXML/georgeEliot.xml"; Log.println (Log.DEBUG, TAG," ИМЯ ФАЙЛА: "+ xmlContent); String [] elementsArray = null; try {DocumentBuilder db = DocumentBuilderFactory.newInstance (). NewDocumentBuilder(); Toast.makeText (this, "xml file:" + xmlContent, 1000) .show (); Document doc = db.parse (new InputSource (new StringReader (xmlContent))); NodeList detailsNodeList = doc.getElementsByTagName (")Подробности "); int numberOfDetails = detailsNodeList.getLength ();

1 Ответ

3 голосов
/ 05 ноября 2011

Вы не должны использовать StringReader для чтения из URL. StringReader читает строку, которую вы передали в конструктор, не загружает файл из Интернета. Вы можете использовать URL класс вместо:

URL xmlContent = new URL("http://webdev4.matcmadison.edu/mab/AmazonXML/georgeEliot.xml");
DocumentBuilder db = DocumentBuilderFactory.newInstance().newDocumentBuilder();
Document doc = db.parse(new InputSource(xmlContent.openStream()));

Другой способ:

Вы можете использовать конструктор из InputSource, который занимает String:

String pathToDocument = "http://webdev4.matcmadison.edu/mab/AmazonXML/georgeEliot.xml";
Document doc = db.parse(new InputSource(pathToDocument));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...