Parsing out XML response to get record Id

lizardbreath

Board Regular
Joined
Feb 23, 2012
Messages
54
Hi There,

I have code that I created that sends a post to a CRM to create a record. After sending the post, I need to consume data from the basic XML Response which is where I am stuck on.

Here is an example of the code to post the data, I had to strip out the actual URL due to security reasons(Bolded section).


Sub CreateRecord()

With CreateObject("WinHttp.WinHttpRequest.5.1")
.Open "POST", "FakeWebsite", False
.SetRequestHeader "content-type", "application/x-www-form-urlencoded; charset=UTF-8"
.SetRequestHeader "user-agent", "user-agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64)"
.Send "First_name=Bob"
MsgBox .ResponseText
End With

End Sub


When I send this request, it will respond with an XML that looks like this below. I need to extract out the LeadId value of "6881061" and the result value of "Success" and put it into two difference cells F2 & G2

<?xml version="1.0" encoding="UTF-8"?>
<ImportResults>
<ImportResult refId="" leadId="6881061" result="Success" message="" />
</ImportResults>
 

Excel Facts

Show numbers in thousands?
Use a custom number format of #,##0,K. Each comma after the final 0 will divide the displayed number by another thousand
Hi There,

Can somebody take a stab at this or at least point me in the right direction? Where I am struggling the most is getting specifically to the Lead Id portion in the XML response and parsing that out.
 
Upvote 0
If you incorporate this in place of your MsgBox line what happens?

VBA Code:
Dim s As String
Dim LeadID As String
s = .ResponseText
LeadID = Split(Split(s, "leadid=", -1, 1)(1), """")(1)
MsgBox LeadID
 
Upvote 0
If you incorporate this in place of your MsgBox line what happens?

VBA Code:
Dim s As String
Dim LeadID As String
s = .ResponseText
LeadID = Split(Split(s, "leadid=", -1, 1)(1), """")(1)
MsgBox LeadID

That did the trick! Very creative. Thank you for the assist!
 
Upvote 0
You're welcome. Thanks for the follow-up. :)

So, you could skip s altogether and just go straight to ..
VBA Code:
Dim LeadID As String
LeadID = Split(Split(.ResponseText, "leadid=", -1, 1)(1), """")(1)
 
Upvote 0
On the off-chance it might be helpful to someone with a similar need, I set out below another approach using the FILTERXML function. Assuming that the XML text is in cell B2:
[F2] =FILTERXML(B2,"//ImportResult/@leadId")
[G2] =FILTERXML(B2,"//ImportResult/@result")
 
Upvote 0

Forum statistics

Threads
1,225,760
Messages
6,186,870
Members
453,380
Latest member
ShaeJ73

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