Форум программистов, компьютерный форум, киберфорум
Java
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
18 / 18 / 15
Регистрация: 27.11.2013
Сообщений: 470

Не удается получить содержимое XML-страницы через XPath

28.04.2018, 22:21. Показов 1054. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Есть задача получить содержимое узлов "title" в xml-документе.
Пытаюсь делать таким вот методом, но что-то не выходит
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
    public void xmlpr() throws IOException, ParserConfigurationException, SAXException, TransformerException, XPathExpressionException {
     
            URL url = new URL("http://freerutor.me/rss.xml");
            URLConnection conn = url.openConnection();
     
            DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
            DocumentBuilder builder = factory.newDocumentBuilder();
            Document doc = builder.parse(conn.getInputStream());
     
            XPathFactory xPathFactory = XPathFactory.newInstance();
            XPath xpath = xPathFactory.newXPath();
     
            //TransformerFactory transformerFactory= TransformerFactory.newInstance();
            //Transformer xform = transformerFactory.newTransformer();
            //xform.transform(new DOMSource(doc), new StreamResult(System.out));
     
     
            NodeList nodeList = (NodeList)xpath.evaluate("/rss/channel/item",doc,XPathConstants.NODESET);
     
            for(int i = 0; i<nodeList.getLength();i++)
            {
                Element element = (Element)nodeList.item(i);
                System.out.println(xpath.compile("/title").evaluate(nodeList.item(i))); //Возвращает в консоли 10 пустых строк
            }
     
        }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.04.2018, 22:21
Ответы с готовыми решениями:

Получить значение через xPath или регулярку
Добрый день. В приведенном примере нужно получить значение индексов, т.е. желательно с тегами: ...

Как получить значение высоты через xpath?
Нужно получить значение из строчек: &lt;div style=&quot;margin-top:0px&quot;&gt; &lt;strong&gt;Height&lt;/strong&gt; &lt;/div&gt; &lt;p/&gt; &lt;div&gt;-...

Получить содержимое CDATA из XML
В xml файле есть кусок который я пытался вытащить, а не выходи помогите его вытащить. &lt;description&gt; &lt;!]&gt; ...

2
Эксперт Java
378 / 370 / 114
Регистрация: 30.06.2010
Сообщений: 1,445
29.04.2018, 02:44
Отладчиком пользоваться умеешь?
0
18 / 18 / 15
Регистрация: 27.11.2013
Сообщений: 470
29.04.2018, 10:10  [ТС]
Цитата Сообщение от LeX Посмотреть сообщение
Отладчиком пользоваться умеешь?
Вроде разобрался. Может кому-нибудь пригодится
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
public class XmlParser {
private static String xmlSource = "http://freerutor.me/rss.xml"; //Ссылка на источник xml
private static String lastFilm ="";
public static Main main = new Main();
static ArrayList<String> searchCopy;
 
 
public static void xmlMethod() throws ParserConfigurationException, IOException, SAXException, XPathExpressionException {
    // Создаем DOM
    DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
    DocumentBuilder builder = factory.newDocumentBuilder();
    Document bbcDoc = builder.parse(xmlSource);
 
    ArrayList<String> search = new ArrayList<String>();
 
    XPath xpath = XPathFactory.newInstance().newXPath();
 
    String expression = "/rss/channel/item"; //выражение для поиска
    NodeList itemNodes = (NodeList) xpath.evaluate(expression, bbcDoc, XPathConstants.NODESET); //создаем список значений
 
 
    for (int i = 0; i < itemNodes.getLength(); i++) {
        String expression2 = "title"; //Ищем заголовки в списке
        Node titleInItemNode = (Node) xpath.evaluate(expression2, itemNodes.item(i), XPathConstants.NODE);
        search.add(titleInItemNode.getTextContent()); // Выводим заголовки
    }
}
}
Но есть другая проблема: как теперь можно передать значение из search в textarea zurnal, находящийся в классе Main?
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
public class Main extends Application{
    //Объявляем переменные для компонентов формы
    Button button;
    Stage window;
    TextArea zurnal;
    TextArea last10;
    TitledPane titledPaneZurnal;
    TitledPane titledPaneLast10;
    TextField timerText;
    Label l1;
 
 
 
public static void main(String[] args) {
    launch(args);
}
 
@Override
public void start(Stage primaryStage) throws Exception {
    window = primaryStage;
    window.setTitle("TimeCheck");
    window.setResizable(false);
    button = new Button("Открыть");
    zurnal = new TextArea(); //Создаем объект текстового поля для текстового поля с журналом
    button.setOnAction(e -> {
        try {
            XmlParser.xmlMethod();
        } catch (ParserConfigurationException e1) {
            e1.printStackTrace();
        } catch (IOException e1) {
            e1.printStackTrace();
        } catch (SAXException e1) {
            e1.printStackTrace();
        } catch (XPathExpressionException e1) {
            e1.printStackTrace();
        }
    });
 
    l1 = new Label("Журнал добавленных материалов");
    last10 = new TextArea(); //Создаем объект текстового поля для последних 10 записей
    VBox layout = new VBox(20);
    layout.getChildren().addAll(l1, zurnal, last10, button);
    Scene scene = new Scene(layout, 700,500);
    window.setScene(scene);
    window.show();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.04.2018, 10:10
Помогаю со студенческими работами здесь

Получить содержимое страницы
Пытаюсь получить html код с сайта rghost.ru unit Unit1; interface uses Windows, Messages, SysUtils, Variants,

Получить содержимое страницы
Здравствуйте Нужно получить содержимое страницы: ...

LINQ to XML или XPath to XML (выбор одного элемента)
Прошу помощи в LINQ или XPath запросе к XML Вот XML: &lt;manifest...

Получить содержимое веб-страницы
Всем привет, как с помощью HTTP-запросов вывести содержимое веб-страницы в listbox? При условии, что в веб-странице находится только текст.

Получить содержимое HTML-страницы
Добрый день, уважаемые участники сообщества! Есть HTML-код нескольких страниц. Мне не нужна разметка, я хочу получить текст (контент...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru