HudsonKane

IE DOM siblings and children

8 posts in this topic

#1 ·  Posted

I have a page with several hundred <div>s, and each <div> has several hundred child <div>s, each with their own children

when I use _IETagNameGetCollection($ie, "div", 0) I get them all, but I need to find a way to get say the 3rd child of the 5th child of the second top level <div>

I have not yet been able to find anything along this line

Is there any way to determine if an element is a child, parent, sibling?

Thank you

Share this post


Link to post
Share on other sites



#2 ·  Posted

You can use any of the IE properties https://msdn.microsoft.com/en-us/library/hh772281(v=vs.85).aspx

However using an index is also quite helpful:

#include <IE.au3>
Local $oIE = _IECreate("https://www.autoitscript.com/forum/topic/187409-ie-dom-siblings-and-children/", 1)
Local $oDivs = _IETagNameGetCollection($oIE, "div")

For $i = 0 To $oDivs.length
    ConsoleWrite("Div (" & $i & "): " & $oDivs($i).InnerText & @CRLF)
Next

 

Share this post


Link to post
Share on other sites

#3 ·  Posted


Signature beginning:   Wondering who uses AutoIT and what it can be used for ?
* GHAPI UDF - modest begining - comunication with GitHub REST API *
ADO.au3 UDF     POP3.au3 UDF     XML.au3 UDF    How to use IE.au3  UDF with  AutoIt v3.3.14.x  for other useful stuff click the following button

Spoiler

Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. 

My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAP * WinSCP UDF * GHAPI UDF - modest begining - comunication with GitHub REST API *

My contribution to others projects or UDF based on  others projects: * _sql.au3 UDF  * POP3.au3 UDF *  RTF Printer - UDF * XML.au3 - BETA * ADO.au3 UDF SMTP Mailer UDF *

Useful links: * Forum Rules * Forum etiquette *  Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * 

Wiki: Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Best coding practices * 

IE Related:  * How to use IE.au3  UDF with  AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities * _IEquerySelectorAll() (by uncommon) * 

I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions *  EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *

"Homo sum; humani nil a me alienum puto" - Publius Terentius Afer
"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming"
:naughty:  :ranting:, be  :) and       \\//_.

Anticipating Errors :  "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty."

Signature last update: 2017-06-04

Share this post


Link to post
Share on other sites

#4 ·  Posted

Hi @HudsonKane.

One of these examples might help

#include <IE.au3>

Global $oIE = _IECreate("https://www.autoitscript.com/forum/topic/187409-ie-dom-siblings-and-children/", 1)

Example01()
Example02()
Example03()

Func Example01()
    Local $oItem = $oIE.document.getElementById("elComment_1346150")
    If (Not IsObj($oItem)) Or (Not ($oItem.children.length>1)) Then Return
    $oItem.children(1)
    If (Not IsObj($oItem)) Or (Not ($oItem.children.length>0)) Then Return
    $oItem.children(0)
    If Not IsObj($oItem) Then Return
    ConsoleWrite("Example01 found a complete match"&@CRLF)
EndFunc

Func Example02()
    Local $oItem = $oIE.document.body
    If (Not IsObj($oItem)) Or (Not ($oItem.children.length>0)) Then Return
    $oItem = $oItem.children(0)
    If (Not IsObj($oItem)) Or (Not ($oItem.children.length>0)) Then Return
    $oItem = $oItem.children(0)
    If Not IsObj($oItem) Then Return
    ConsoleWrite("Example02 found a complete match"&@CRLF)
EndFunc

Func Example03()
    Local $oItem = $oIE.document
    If (Not IsObj($oItem)) Then Return
    $oItems = $oItem.querySelectorAll("div>div:nth-of-type(5)>div:nth-of-type(1)");to use the retusn use length property and $oItems($i)
    If (Not IsObj($oItem)) Or $oItem.length=0 Then Return
    ConsoleWrite("Example03 found a complete match"&@CRLF)
EndFunc

 

Share this post


Link to post
Share on other sites

#5 ·  Posted

Thank you, I didn't realize I could use querySelectorAll().  I am new to this and having an issue

this gives me the html I expect 

$a = $ie.document.getElementById("main_div_id")
ConsoleWrite($a.outerHtml)

but both of these yield empty html

$a = $ie.querySelectorAll("#main_div_id > div:nth-of-type(1)")
ConsoleWrite($a.outerHtml)
or
$a = $ie.document.getElementById("main_div_id")
If (IsObj($a)) Then
    Local $b = $a.querySelectorAll("div:nth-of-type(1)")
    If IsObj($b) Then
       ConsoleWrite($b.outerHtml)
    EndIf
EndIf

 

Share this post


Link to post
Share on other sites

#6 ·  Posted

This appears to be what I want, for the second item at least

ConsoleWrite($b.item(0))

Share this post


Link to post
Share on other sites

#8 ·  Posted

Would help if I actually read and followed your advice....

This is working great

Local $document = $ie.document
Local $a = $document.querySelectorAll("#main_div_id > div:nth-of-type(1)")
if IsObj($a) Then
    ConsoleWrite($a.item(0).outerHtml)
EndIf

Thanks so much!

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!


Register a new account

Sign in

Already have an account? Sign in here.


Sign In Now

  • Similar Content

    • Spask
      By Spask
      Hi, I'm trying to find a text value inside of a html.
      This is what the line looks like normally:
      <p id="line1" class> <span class="bot">TEXT HERE</span> </p> The text then changes to a non breaking space:
      <p id="line1" class> <span class="bot">&nbsp;</span> </p> And then it changes back to normal text but it's different every time.
      Can I code this so that it grabs the text every time it changes and has a variable that represents it?
      I currently have this inside of my loop:
      $span = .document.getElementsByTagName("span") For $text In $span If $text.value = "&nbsp;" Then Sleep(50) MsgBox(0,0,0) ;messagebox to test if it can be found, but I don't know how to grab the text EndIf Next The problem is that there are many other lines in the html that have the same span but are called "line3", "line5", etc and the one I need is from "line1".
      I will appreciate if anyone can help with this!
    • sree161
      By sree161
      Hi,
      i have a code which generates two numeric outputs.i have to save them in excel.
      Is there any way to export them to specific cells in excel???
    • electrons
      By electrons
      hi  , hope  you all doing well 
       cant find any elements on the page ?  and the right click mouse dont work too?
      iam trying with more than method , i need help please!!
       

    • ur
      By ur
      I have kept below line to wait for IE to load the site completely and continue.
      _IELoadWait($oIE)
       
      But, the code is continuing without waiting for it and I my execution is failing as the elements are not loaded completely.

       
      Any suggestions for alternate code to wait for the browser to load completely?
       
    • ur
      By ur
      We can select elements in IE using their IDs as below.
      Local $oDiv = _IEGetObjById($oIE, "x-auto-16-input") But to one button in the webpage, there is no ID to it.
      In selenium we have option to select this element using the CssSelector and clicked the button using below code in c# selenium.
      driver.FindElement(By.CssSelector("button.x-btn-text")).Click(); What is the alternative for this in AUtoIT?