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

Posted July 24, 2007 at 6:24 PM

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:

 Launch code in new window » Download code as text file »

  • <!--- 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.

Download Code Snippet ZIP File

Post Comment  |  Ask Ben  |  Other Searches  |  Print Page





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 »
7,572 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 »
7,572 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 Comment  |  Ask Ben

Recent Blog Comments
Mar 21, 2010 at 3:59 PM
Exploring ColdFusion Component Runtime Class Properties And Serialization
@Elliott, according to Ben's experiment, serializeJSON() doesn't access the private data by default - it doesn't even access the getHair() method - so trying to clone a Girl.cfc via serializeJSON/des ... read »
Mar 21, 2010 at 3:49 PM
Ask Ben: Javascript String Replace Method
I'm confused a bit by what you are asking, but if had this sentence: The color, red, is in the style statement; style: red;. and wanted to remove all or change all of the commas, colons, and semi-c ... read »
Mar 21, 2010 at 3:13 PM
Ask Ben: Javascript String Replace Method
I am trying to make a java program to count the number of times that these punctuation marks occur in a body of text: , : ; . ! - ' " ? / \ I am using this piece to ferret out the commas: numcommas ... read »
Mar 21, 2010 at 11:13 AM
A New Wrist Pain
@chiropractor suwanee, Spoken like someone trying to sell something. Other than for minor, temporary relief from some back pain, chiropractic treatment is nothing but placebo effect and quackery. ... read »
Mar 21, 2010 at 6:32 AM
ColdFusion CFPOP - My First Look
Apologies... The field name in the db for C. is "BounceCode" It stores the code / message which is returned in the email. Sorry for the confusion. ... read »
Mar 21, 2010 at 6:29 AM
ColdFusion CFPOP - My First Look
@Jose Galdamez, Hi Ben and Jose 1st of all.. big thanks to Jose for his Skype chat a few weeks back. Your time was much appreciated. I have come up with a rather unelegant solution to my problem a ... read »
Mar 21, 2010 at 3:42 AM
A New Wrist Pain
Chiropractic treatment is one of the best methods for treating numerous health problems naturally. After years of experience being a chiropractor, I have found that it is a powerful way to solve many ... read »
Mar 20, 2010 at 12:07 PM
Drawing On The iPhone Canvas With jQuery And ColdFusion
Simply awesome. Saved my day. ... read »