UK License Plate Searcher

Hgreen1601

New Member
Joined
Jun 15, 2021
Messages
18
Office Version
  1. 2016
Platform
  1. Windows
I have been trying to make a macro where I enter a license plate and it searches the gov.uk website (https://vehicleenquiry.service.gov.uk) and returns the cylinder capacity.

Relatively new to macro writing so any explanation would be appreciated, currently have numerous errors.

VBA Code:
Sub EngineSearch()

    Dim Tool      As Object
    Dim Var     As Variant
    Dim element As Variant
    Dim WrkBk   As Workbook
    Dim WrkSht  As Worksheet
   
    Set WrkBk = ThisWorkbook
    Set WrkSht = WrkBk.ActiveSheet

    For i = WrkSht.Range("E3").Value To WrkSht.Range("F3").Value
    'Have put the cells of my data range within these values
   
   
    Set Tool = CreateObject("InternetExplorer.Application")
    Tool.navigate "[URL]https://vehicleenquiry.service.gov.uk/[/URL]"

    Tool.Visible = False
   
    Application.Wait (Now + TimeValue("0:00:01"))

    Set frm = Tool.document.getelementbyid("wizard_vehicle_enquiry_capture_vrn_vrn")

    frm.Value = WrkSht.Cells(i, 2).Value
       
    Tool.document.getelementbyid("submit_vrn_button").Click
   
    Application.Wait (Now + TimeValue("0:00:01"))

    Tool.document.getelementbyid("yes-vehicle-confirm").Click
    Tool.document.getelementbyid("capture_confirm_button").Click
   
    Application.Wait (Now + TimeValue("0:00:01"))

    Set HtmlType = ie.document.getelementbyid("cylinder_capacity")
    WrkSht.Range("C" & i) = Right(HtmlType.innerText, 7)
  

    Tool.Quit


    Next i
   
Exit Sub
 

Excel Facts

What does custom number format of ;;; mean?
Three semi-colons will hide the value in the cell. Although most people use white font instead.
  • First remove the duplicates plates as it's a non sense to request any duplicate plate …

  • For one of the unusual errors I decided to leave the late binding for an early binding of the IE object
    so you must activate the reference Microsoft Internet Controls on VBE side via its Tools menu.
VBA Code:
Sub Wait4Ready(oIE As InternetExplorer)
         While oIE.Busy Or oIE.ReadyState < 4:  DoEvents:  Wend
         On Error Resume Next
    Do
         Err.Clear
         While oIE.Document.ReadyState <> "complete":  DoEvents:  Wend
    Loop While Err.Number
End Sub

Sub DemoIE2()
    Dim V, S&, N&, oIE As InternetExplorer, R&, D As Date, oElt As Object
        V = [C1].CurrentRegion.Value2:  If UBound(V) < 3 Then Beep: Exit Sub
        ActiveWindow.ScrollRow = 1
        S = ActiveWindow.VisibleRange.Rows.Count - 2
        N = S + 1
        On Error GoTo Fin
    For R = 3 To UBound(V)
        If Not IsEmpty(V(R, 1)) And (IsEmpty(V(R, 2)) Or V(R, 2) Like "¤ e*") Then
            Set oIE = New InternetExplorer
                oIE.Navigate "https://vehicleenquiry.service.gov.uk/"
                Cells(R, 3).Interior.Color = vbYellow
            If R > N Then
                If N + S >= UBound(V) Then N = UBound(V) + 1: ActiveWindow.ScrollRow = N - S _
                                      Else ActiveWindow.ScrollRow = N: N = N + S
            End If
                Wait4Ready oIE
                D = Now + 0.0001
                On Error Resume Next
            Do
                DoEvents
                Set oElt = oIE.Document.forms(0)("wizard_vehicle_enquiry_capture_vrn_vrn")
            Loop While D > Now And oElt Is Nothing
                On Error GoTo Fin
            If oElt Is Nothing Then
                Cells(R, 4).Value2 = "¤ error 1"
            Else
                    oElt.Value = V(R, 1)
                    oElt.form("submit_vrn_button").Click
                    Set oElt = Nothing
                    Wait4Ready oIE
                If IsObject(oIE.Document.querySelector("h1.govuk-heading-l.info-panel")) Then
                    Cells(R, 4).Value2 = "not found"
                Else
                        D = Now + 0.0001
                        On Error Resume Next
                    Do
                        DoEvents
                        Set oElt = oIE.Document.all("yes-vehicle-confirm")
                    Loop While D > Now And oElt Is Nothing
                        On Error GoTo Fin
                    If oElt Is Nothing Then
                        Cells(R, 4).Value2 = "¤ error 2"
                    Else
                            oElt.Click
                            Set oElt = Nothing
                            oIE.Document.all.capture_confirm_button.Click
                            Wait4Ready oIE
                            D = Now + 0.0001
                            On Error Resume Next
                        Do
                            DoEvents
                            Set oElt = oIE.Document.querySelector("#fuel_type>dd")
                        Loop While D > Now And oElt Is Nothing
                            On Error GoTo Fin
                        If oElt Is Nothing Then
                            Cells(R, 4).Value2 = "¤ error 3"
                        Else
                            Cells(R, 4).Resize(, 2).Value2 = Array(oIE.Document.querySelector("#engine_capacity>dd").innerText, oElt.innerText)
                            Set oElt = Nothing
                        End If
                    End If
                End If
            End If
                Cells(R, 3).Interior.ColorIndex = xlNone
        End If
Fin:
            If Err.Number <> -2147023706 And Not oIE Is Nothing Then oIE.Quit
            Set oIE = Nothing
        If Err.Number Then
            Debug.Print Err.Number; " : "; Err.Description:  Beep
            If R Then Cells(R, 3).Interior.ColorIndex = xlNone: Cells(R, 4).Value2 = "¤ err #" & Err.Number
            Exit For
        End If
    Next
End Sub
 
Upvote 0
Tested and runs very well.

Thank you Marc, appreciate the effort in this!
 
Upvote 0
In your real worksheet, what could be the maximum number of plates within your list ?​
 
Upvote 0
As it depends on the free memory (RAM) of your computer I may have a Windows variation to achieve it a little bit faster if necessary …​
It's a trick for web requesting - should inspect again this way if I could success - but as here it's for piloting Internet Explorer​
it should need more free RAM as it may hang / crash your system.​
So if interested post a list of 50 unique (non duplicate) plates as my tests slow old laptop with its few RAM can not handle more …​
 
Upvote 0
Currently have 16GB of RAM so don't think this should be an issue!

Again, thanks for your help!
 
Upvote 0
As it depends on the free memory so the more applications opened the less free memory the more chances Windows hangs or even crashes …​
And for speed performance if some others applications use some web access the VBA procedure execution may last more …​
 
Upvote 0

Forum statistics

Threads
1,224,827
Messages
6,181,195
Members
453,021
Latest member
pingpong7117

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top