es:identificacion_de_objetos_por_xpath [TAST DokuWiki ]

User Tools

Site Tools


Sidebar

Primeros pasos en TAST

Que es UML

Configuración del sistema para el uso de TAST

Preguntas más frecuentes

Problemas reconocidos

Indice de la herramienta TAST

Adaptadores de TAST

Ejemplos de adaptadores

TAST Integraciones

Características de interés

Documentación de administración técnica

Recomendaciones para modelar

Formación en la herramienta TAST

es:identificacion_de_objetos_por_xpath

Identificación de objetos por XPath

En las siguientes líneas, el usuario será capaz de encontrar pistas y consejos sobre como identificar objetos vía Xpath.

Xpath es una manera de identificar objetos en base a la ruta a la que el objeto esta anidado. Como ejemplo: el Xpath “/html/body/div[2]/div/div/footer/section[3]/div/ul/li[3]/a” buscará en el cuerpo del html un elemento “div[2]” luego buscará un div, tras otro, un footer, y así hasta el final.

Hay básicamente dos formas de usar un Xpath: usando el Xpath entero o buscando solo un fragmento (para este último en vez de abrirse con / se abre con “/ /”). Como siempre, en pruebas, es bastante importante tener claro que el Xpath que se escribe es único y representa solamente un elemento. Como recordatorio, el ID del atributo es único.

Igualmente, dado que esto puede volverse demasiado largo, hay algunas maneras para acortarlo, para esto necesitamos saber su sintáxis:

Expresión XPath Descripción Ejemplo de Expresión Ejemplo de Significado
/ Selección del nodo de ruta. (…)/b/a Elemento ”a” hijo de ”b”, hijo de ”(…)“.
/ / Selecciona cualquier nodo del nodo actual que coincide con la selección no importa donde esté. b / / a(…) Todos los elementos ”a(…)” hijos de ”b”.
* Coincide con cualquier nodo. b / * / a Cualquier elemento ”a” del que es nieto de ”b“.
. Selecciona el nodo actual. ./ /de Cualquier elemento ”de” que está dentro de uno o más niveles del nodo actual.
.. Selecciona el padre del nodo actual. abc[../mg] Cualquier elemento ”abc” que tiene un hermano ”mg”.
@ Selecciona atributo. a[@bcd] Elemento ”a” con un atributo ”bcd”.
@ = Selecciona atributos con valor. a[@bcd=“hola”] Elemento ”a” con ”bcd” como atributo igual a hola.
@* Coincide con cualquier atributo. a[@*=“hola”] Elemento ”a” con cualquier atributo igual a hola.
last() Coincide con el ultimo elemento. b / a[last()] Ultimo elemento ”a” hijo de ”b“.
[] Elemento que contiene algo. c[hello] / b[@a] Elemento ”b” elemento que contiene un atributo ”a” hijo de atributo ”c” que contiene el elemento hello.
[][] Elemento que contiene dos o mas cosas (se añaden[] por cada uno). a[@b][@c] Elemento ”a” con los dos atributosb” y ”c”.
[n] El elemento “n” en un array. b/a[3] Tercer elemento ”a” hijo de ”b“.
!= Desigual. a[@bcd!=“hola”] Elemento ”a” con atributo ”bcd” no igual a hola.
last() Último elemento. b/a[last()] El último ”a” hijo de ”b“.
() Grupo de operaciones para establecer prioridades. (de/mg)[3] El tercer set entero de ”de/mg“.
and Uso lógico del AND. a[b and c] Elemento ”a” que contiene ambosb” y ”c“.
or Uso lógico del OR . de[@mg or @dus] Elemento ”de” que contiene los atributos ”mg” o ”dus”.
contains() Coincide con todos los elementos que parcialmente contienen lo que este dentro de los “()”. de[contains(.,'click here')] Elementos ”de” que contienen ”click here“.
starts-with() Coincide todos los elementos que estén contenidos en “()”. de[starts-with(@id,'id-name')] Elementos ”de“ que empiezan por ”id-name(…)“.
[ .=''] Coincide todos los elementos dentro de un string. de[.='string 1 of 6'] Elementos ”de” con el string ”string 1 of 6“.
normalize-space() Coincide los elementos con un string ignorando espacios en blanco. de[normalize-space()='mg'] Elementos ”de” con el string ”mg” o ” mg” o ”mg ” o ” mg “.
text() Selecciona los elementos con un texto especifico dentro. de[text()=“mg”] Elementos ”de” con string ”mg” en el campo de texto.
[ / @ ] Selecciona elementos que tienes algún hijo especifico. / / de[mg/@attr1='nrw'] Elementos ”de” con ”mg” hijo de ”attr1” igual a ”nrw“.


Como obtener el Xpath de un documento XML

Como obtener el Xpath de nodo XML con Notepad++:

1. Dentro de Notepad++ ir a plugins de aquí al gestor de plugins y elegir mostrar gestor de plugins.
2. Instalar XML Tools (herramientas XML).
3. Reiniciar el Notepad++.
4. Cargar el documento XML que deseas.
5. Poner el cursor sobre el nodo del cual necesitas el Xpath.
6. Ir a Plugins, despues a XML Tools continuamos a ruta Xpath actual (Hotkey: Ctrl + Alt + Shift + P).

A continuación tendremos el Xpath copiado en el portapapeles.

es/identificacion_de_objetos_por_xpath.txt · Last modified: 2020/10/22 12:43 by montse