Select Any XML Node With A Given Value Using ColdFusion And XPath

Posted July 24, 2007 at 6:24 PM by Ben Nadel

Tags: ColdFusion

Earlier today, on the CF-Talk list, Brad Wood was asking about selecting any node from an XML document based on its text value (text child node). In my ColdFusion, XmlSearch, and XPath tutorial I did a bunch of stuff with "any node" examples and also with text-based examples, but I didn't do anything that combined the two. I didn't know if ColdFusion's XmlSearch() method would hiccup if you tried to use "//*" in conjunction with a text() predicate:

  • <!--- Build an XML document object. --->
  • <cfxml variable="xmlData">
  •  
  • <root>
  • <a1>Meep</a1>
  • <a2>Meep</a2>
  • <a3>
  • <b1>Dink</b1>
  • <b2>Meep</b2>
  • </a3>
  • <a4>Blam</a4>
  • </root>
  •  
  • </cfxml>
  •  
  •  
  • <!---
  • Get all nodes in the XML document that have the
  • child text node, "Meep". We don't care where the
  • node is or they are related... we only care about
  • this inner text value.
  • --->
  • <cfset arrNodes = XmlSearch(
  • xmlData,
  • "//*[ text() = 'Meep' ]"
  • ) />
  •  
  • <!--- Dump out results. --->
  • <cfdump
  • var="#arrNodes#"
  • label="All Nodes By Text Value"
  • />

I was pleased to see that this functions exactly like I hoped it would, giving us the following CFDump output:


 
 
 

 
XML Nodes Found Based On Their Text Value  
 
 
 

Notice that it found the a1, a2, and b2 element nodes based purely on their nested text node. Good stuff.




Reader Comments

Jul 24, 2007 at 10:57 PM // reply »
50 Comments

Good stuff! FYI - There is a great Firefox extension called "Xpather" that is great for displaying the Xpath info for elements on a page...


Jul 25, 2007 at 8:02 AM // reply »
10,640 Comments

Yeah, I think someone else mentioned XPather too. I really gotta check that out. FireFox is the most badass browser.


db
Jul 25, 2007 at 8:28 AM // reply »
3 Comments

firebug does a nice job of showing xpath - open the console and click the 'dom' tab. when you mouseover the elements (in blue) in the list on the right, the xpath is displayed, and the element is hilited on the page. right click to copy the xpath.


Jul 25, 2007 at 8:38 AM // reply »
10,640 Comments

@DB,

Good call. I just tried it (in the email I got) and it works like a charm:

/html/body/div[2]/div[2]/div[3]/table/tbody/tr/td/div/div[2]/div[4]/
table/tbody/tr/td/div/div/div/p[2]

... I gMail as a lot of stuff going on in it's pages :)

What would I do without FireBug??


Jul 25, 2007 at 8:56 AM // reply »
50 Comments

Sweet - I think Xpather is easier to use - it's more direct - I select the element, right-click and select "Show in Xpather" - with Firebug I have to dig a bit - but thats useful for finding elements that may not be visible on the page. Good stuff!


db
Jul 25, 2007 at 3:03 PM // reply »
3 Comments

yeah, those lists can be too much information, sometimes. if you right click on the page and select 'inspect element', you get more specific info. a bar at the top of the console has the element and its parents, and the xpath info.


Jun 7, 2009 at 3:34 PM // reply »
1 Comments

if you right click on the page and select 'inspect element', you get more specific info. a bar at the top of the console has the element and its parents, and the xpath info.


Post A Comment

Comment Etiquette: Please do not post spam. Please keep the comments on-topic. Please do not post unrelated questions or large chunks of code. And, above all, please be nice to each other - we're trying to have a good conversation here.

Please review the following issues:

Author Name:


Author Email:

Author Website:

Comment:

Supported HTML tags for formatting: <strong>bold</strong>   <em>italic</em>   <code>code</code>







  • Help Wanted - Find Your Next ColdFusion Job
InVision App - Prototyping Made Beautiful With Prototyping Tools Ben Nadel's Company - Epicenter Consulting Recent Blog Comments
Feb 10, 2012 at 7:21 PM
jQuery AJAX Strips Script Tags And Inserts Them After Parent-Most Elements
Update! Instead of $(eval(options.insertAfter)).after(data['insertData']); I now use: var ajaxNode = document.createElement('span'); var parent = $(eval(options.insertAfter))[0].parentNode; ... read »
Feb 10, 2012 at 6:18 PM
jQuery AJAX Strips Script Tags And Inserts Them After Parent-Most Elements
encountered this same, what I consider, jQuery bug last week. I'm building a site in which I load some content via AJAX. This content contains Linkedin share button placeholders which Linkedin API ne ... read »
Feb 10, 2012 at 11:30 AM
Cross-Origin Resource Sharing (CORS) AJAX Requests Between jQuery And Node.js
After you understand the concepts here, this is an awesome cheatsheet for enabling CORS in just about anything http://enable-cors.org/ ... read »
JM
Feb 10, 2012 at 9:10 AM
My Safari Browser SQLite Database Hello World Example
@Amy, Here is a very good tutorial on how to use JOIN: http://www.sqltutorial.org/sqljoin-innerjoin.aspx ... read »
Feb 10, 2012 at 4:42 AM
Building A Twitter-Inspired RESTful API Architecture In ColdFusion
This is great, very useful Ben. I spotted a small typo in the api.cgm listing: <cfthrow type="Unauthroized" /> Cheers Stefan ... read »
Feb 9, 2012 at 10:35 PM
CFDirectory Filtering Uses Pipe Character For Multiple Filters (Thanks Steve Withington)
I was wondering if there would be a filter you could apply so that you got everything but what you included in the filter. As in show me all docs that are not a .pdf. ... read »
Feb 9, 2012 at 10:29 PM
Learning ColdFusion 9: Application-Specific Data Sources
@Ben, No offence, but if people were really wanting advanced features they would be using a platform like ASP.NET MVC. CFML is so structurally compromised as a tag-based scripting language that ... read »
Feb 9, 2012 at 10:03 PM
Subversion - Cleanup Failed To Process The Following Paths
@Leviaguirre, do you still have problems with this? ... read »