Menavigasi HTML

Web Scraping di R

Timo Grossenbacher

Instructor

HTML seperti pohon

<html>
  <body>
    <div>
      <p>Paragraf pertama.</p>
    </div>
    <div>
      Bukan paragraf sebenarnya, 
      tetapi ada <a href="#">tautan</a>.
    </div>
    <p>Paragraf tanpa 
      div pembungkus.</p>
  </body>
</html>

Pohon HTML

Web Scraping di R

HTML seperti pohon

<html>
  <body>
    <div>
      <p>Paragraf pertama.</p>
    </div>
    <div>
      Bukan paragraf sebenarnya, 
      tetapi ada <a href="#">tautan</a>.
    </div>
    <p>Paragraf tanpa 
      div pembungkus.</p>
  </body>
</html>

Pohon HTML 2

Web Scraping di R

HTML seperti pohon

<html>
  <body>
    <div>
      <p>Paragraf pertama.</p>
    </div>
    <div>
      Bukan paragraf sebenarnya, 
      tetapi ada <a href="#">tautan</a>.
    </div>
    <p>Paragraf tanpa 
      div pembungkus.</p>
  </body>
</html>

Pohon HTML 3

Web Scraping di R

Menavigasi pohon dengan rvest

<html>
  <body>
    <div>
      <p>Paragraf pertama.</p>
    </div>
    <div>
      Bukan paragraf sebenarnya, 
      tetapi ada <a href="#">tautan</a>.
    </div>
    <p>Paragraf tanpa 
      div pembungkus.</p>
  </body>
</html>
html <- read_html(html_document)

html_children(html)
{xml_nodeset (1)}
[1] <body>\n    <div>\n  < ...
html %>% html_children()
html %>% html_children() %>% html_text()
[1] "\n    \n      The first paragraph.\n   
\n    \n      Not an actual paragraph, \n      
but with a link.\n    \n    A paragraph ...
Web Scraping di R

Menavigasi ke node dengan selektor

<html>
  <body>
    <div>
      <p>Paragraf pertama.</p>
    </div>
    <div>
      Bukan paragraf sebenarnya, 
      tetapi ada <a href="#">tautan</a>.
    </div>
    <p>Paragraf tanpa 
      div pembungkus.</p>
  </body>
</html>
html <- read_html(html_document)

html %>% html_element('body')
{xml_nodeset (1)}
[1] <body>\n    <div>\n  < ...
html %>% html_elements('div p')
{xml_nodeset (1)}
[1] <p>Paragraf pertama.</p>
Web Scraping di R

Menavigasi ke node dengan selektor

<html>
  <body>
    <div>
      <p>Paragraf pertama.</p>
    </div>
    <div>
      Bukan paragraf sebenarnya, 
      tetapi ada <a href="#">tautan</a>.
    </div>
    <p>Paragraf tanpa 
      div pembungkus.</p>
  </body>
</html>
html %>% html_elements('p')
{xml_nodeset (2)}
[1] <p>Paragraf pertama.</p>
[2] <p>Paragraf tanpa div pembun...
html %>% html_elements('div') %>% 
    html_elements('p')
{xml_nodeset (1)}
[1] <p>Paragraf pertama.</p>
Web Scraping di R

Mengekstrak atribut

html %>%
    html_element('a') %>%
    html_attr('href')
[1] #
html %>%
    html_element('a') %>%
    html_attrs()
href 
 "#"
Web Scraping di R

Ayo berlatih!

Web Scraping di R

Preparing Video For Download...