Programatically retrieving data from a website into a database

 

Summary: Our client wanted to extract data from a web portal. We wrote a VBA script to the requested information and store it in an Access database. The example below demonstrates the same technology, but the data is stored in Excel.

Edit: 9/9/2016: I posted a download to the file here.

Technologies

  • Microsoft Access: Data and VBA
  • Microsoft Internet Controls
  • Microsoft HTML Document Control*

An understanding of the HTML Document Object Model (DOM) will help you A LOT.

 

Scrape web content using VBA

Screen scraping used to be a way to grab characters off of mainframes and AS/400’s. It is much easier to scrape web site information due to the DOM. Actually, it’s not scraping at all – more of a structured retrieval of data from HTML.

I cannot provide the exact code from the above project as it was a bought and paid for by our client and belongs to them. I’ll explain the methodology and provide sample code to retrieve web content. I’ll also demonstrate the retrieving information from the DOM.

I will provide the source code for you to retrieve information from my blog’s root page – the one listing the most recent 10 blog entries found at the link below:
http://www.pulseinfomatics.com/blog/

I’ll explain a couple critical differences in the code provided and the code we built for our client.

 

Create an Access table: tblWebData

With the following fields:

  • wd_uno (autonumber, key)
  • ArticleTitle (Short Text, 255)
  • ArticleURL (Short Text, 255)
  • ArticleAuthor (Short Text, 255)
  • ArticleSummary (Long Text)
  • DateRetrieved (date/time)

Note, I would size them differently but I was in a hurry. I’ll leave that to you.

 

Create an Access form (frmWebTest)

I put a single button on the form:btnGetWebData

This is the code for that button plus another sub-routine.

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
411             
Private Sub btnGetWebData_Click()
Dim strURL
Dim iPage As InternetExplorer
Dim iHTML As HTMLDocument
Set iPage = New InternetExplorer
iPage.Navigate strURL
 
While iPage.ReadyState <> READYSTATE_COMPLETE
' I'll make a big assumption that it will get to the page, otherwise, you'd want to have a way to catch a timeout
 DoEvents
Wend
 
Set iHTML = iPage.Document 'put the HTML from the navigated webpage into the HTML Document object
 
'look for the "article" tag and return number of articles on the page
intNumA = iHTML.getElementsByTagName("article").length
 
For x = 1 To intNumA 'loop through each article
 
 strAURL = iHTML.getElementsByTagName("article").Item(x - 1).getElementsByTagName("header").Item(0).getElementsByTagName("a").Item(0).href
 strATitle = FixQuote(iHTML.getElementsByTagName("article").Item(x - 1).getElementsByTagName("header").Item(0).getElementsByTagName("a").Item(0).innerText)
 strAAuthor = iHTML.getElementsByTagName("article").Item(x - 1).getElementsByTagName("header").Item(0).getElementsByTagName("a").Item(1).innerText
 strASummary = FixQuote(iHTML.getElementsByTagName("article").Item(x - 1).getElementsByTagName("p").Item(0).innerText)
 SaveWebInfo strAURL, strATitle, strAAuthor, strASummary
  
Next
 
Set iHTML = Nothing
Set iPage = Nothing
 
End Sub
 
Sub SaveWebInfo(inURL, inTitle, inAuthor, inSummary)
Dim strSQL As String
strSQL = "INSERT INTO tblWebData (ArticleURL,ArticleTitle,ArticleAuthor,ArticleSummary,DateRetrieved) " & _
 "VALUES ('" & inURL & "','" & inTitle & "', '" & inAuthor & "','" & inSummary & "', #" & Now() & "#)"
DoCmd.SetWarnings False
DoCmd.RunSQL strSQL
DoCmd.SetWarnings True
End Sub

 

FixQuotes Function

Variations of this functionality can be found in various places around the web. I grabbed mine from this blog.

http://mikeperris.com/access/escaping-quotes-Access-VBA-SQL.html

It ensures you don’t get errors when trying to save text with quotes.

1
2
3
4
5
6
7
8
9
10
11
   12
' courtesy "dschmidt333", utteraccess.com
Function FixQuote(FQText As String) As String
On Error GoTo Err_FixQuote
FixQuote = Replace(FQText, "'", "''")
FixQuote = Replace(FixQuote, """", """""")
Exit_FixQuote:
Exit Function
Err_FixQuote:
MsgBox Err.Description, , "Error in Function Fix_Quotes.FixQuote"
Resume Exit_FixQuote
Resume 0 '.FOR TROUBLESHOOTING
End Function

 

Some DOM elements and nesting explained

My goal is not to teach you how to navigate the DOM. You can start here to learn more about the DOM.

intNumA = iHTML.getElementsByTagName(“article”).length
Returns the number of “article” tags on the page. For my blog, each article is contained in an article tag.

 

GetElementsByTagName(“article”)
Returns an array of any elements with the tag name (“article”)

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

You can now loop through each article to retrieve article-specific data.

iHTML.GetElementsByTagName(“article”).Item(x – 1)
Refers to a specific article tag and it’s associated HTML. x started counting 1. Arrays start at 0. x – 1 ensures you are referring to the correct article tag.

Once you refer to a specific article (x – 1) the objects you refer to after that relate only to that specific article. Elements that are not encapsulated (nested) in that “article” tag are ignored. Remember that when reading the href and innerTEXT references below.

 

.getElementsByTagName(“a”).Item(0).href
The first a tag href is the link to the blog entry.

The second href is the blog author. Subsequent hrefs, if they exist, link to categories. But I am only concerned with item(0) and item(1).

The innerTEXT of each hrefs returns the linked text. The article URL’s innerTEXT is the title. The author URL’s innerTEXT is the author name.

 

getElementsByTagName(“p”).Item(0).innerText
References the only paragraph in each article, the summary text.

That gives you some idea of how to reference items in the HTML Document Object Model.

 

How my client’s project differed.

In order to retrieve several pages of profiles, I had to:

  • navigate to a page
  • loop through information from a list
  • present the user information and choices as to what they wanted to copy
  • retrieve the data from a list
  • navigate to sub-pages if they exist
  • retrieve information from sub-pages
  • move to the next page and repeat

 

Example Video

Here’s an example where I navigate the DOM on our website

 

Download File

pulse-grab-web-data1.zip

 

[출처] https://www.pulseinfomatics.com/programatically-retrieving-data-from-a-website-into-a-database/

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
1195 ePub 의 개요 [전자책 표준] 가을의 곰을... 2009.09.03 30229
1194 ubuntu에서 tcl/tk 설치 가을의 곰을... 2010.08.08 25232
1193 ProGuard - 자바 역컴파일 방지 [1] 가을의 곰을... 2010.01.14 22719
1192 안드로이드 구조분석 wiki file 가을의 곰을... 2010.01.10 22130
1191 C Programming Links 가을의 곰을... 2009.09.02 21174
1190 자바에서 x86 어셈블리로 프로그래밍: x86 Assembly Programming in Java Platform 가을의 곰을... 2011.11.15 20535
1189 ubuntu에서 wxPython 설치하기 가을의 곰을... 2010.08.08 19730
» Programatically retrieving data from a website into a database file 졸리운_곰 2017.02.26 18864
1187 ▣ Emacs 사용법 ver 3.0 [1] 가을의 곰을... 2010.01.02 18685
1186 GOF 디자인패턴 file 가을의 곰을... 2009.12.05 17690
1185 emacs 사용법 file 가을의 곰을... 2010.01.03 17418
1184 미래 네트워크 연구 동향 file 가을의 곰을... 2009.12.13 17234
1183 소스인사이트 단축키 (2) 가을의 곰을... 2010.10.11 17003
1182 Android 빌드하여 AVD 생성 및 시뮬에 올리기 file 가을의 곰을... 2010.08.15 16946
1181 기계학습 (머신러닝:Machine Learning) 참고자료 링크 : 머신러닝 : 기계 학습 프로그래밍 자료 졸리운_곰 2014.11.29 16075
1180 Overview of MS Fortran Compiler 가을의 곰을... 2009.09.04 15743
1179 Java GUI 프로그래밍 가을의 곰을... 2011.06.05 15694
1178 < 목표성취의 7단계 > 가을의 곰을... 2009.08.17 15465
1177 JQuery의 힘으로 제작된 17 가지 오픈소스 웹 게임들 가을의 곰을... 2013.01.02 15343
1176 Spring 3 MVC Hello World Example file 가을의 곰을... 2011.11.01 14983
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED