Solved

C#: how to use xpath to escape a token

Posted on 2014-04-30
5
682 Views
Last Modified: 2014-05-06
how do i use the below:

XmlNode node = doc.SelectSingleNode("/edt/ce[normalize-space(desc)='" + msg + "']/code");

in the event that the msg parameter contains an apostrophe or other special characters (since it is a string). (i.e. - Can't create Server object). This string exists in the xml . the <desc> tag does contain  special characters as well (since it's a string).

how do i escape special grammar characters like commas ,colon, parenthesis,  dash, slash , underscore)
0
Comment
Question by:badtz7229
  • 3
  • 2
5 Comments
 
LVL 18

Expert Comment

by:zc2
ID: 40032721
Replace the invalid characters in the msg with entities, something like
msg = msg.replace( "'", "&#x27;" )
0
 

Author Comment

by:badtz7229
ID: 40032729
if i use a replace it won't find it in the xml then.
for example
msg =  Can't create Server object

and my xml file contains

<edt name="errors">
      <ce>
            <code>111</code>
            <desc>Not here</desc>
      </ce>
      <ce>
            <code>222</code>
            <desc>Can't create Server object </desc>
      </ce>
</edt>
0
 
LVL 18

Accepted Solution

by:
zc2 earned 500 total points
ID: 40032786
You are right, entity does not work.
If the apostrophe only could be in the string, then we could avoid using it in the xpath:
XmlNode node = doc.SelectSingleNode("/edt/ce[normalize-space(desc)=\"" + msg + "\"]/code");
0
 

Author Comment

by:badtz7229
ID: 40032801
@ zc2
your last comment worked successfully.
thanks.
0
 
LVL 18

Expert Comment

by:zc2
ID: 40032848
This should work even if the search string contains both single and double quote characters:
            msg = "concat('" + msg.Replace( "'", "',\"'\",'" ) + "')";
            XmlNode node = doc.SelectSingleNode("/edt/ce[normalize-space(desc)=" + msg + "]/code");

Open in new window

0

Featured Post

DevOps Toolchain Recommendations

Read this Gartner Research Note and discover how your IT organization can automate and optimize DevOps processes using a toolchain architecture.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction In my previous article (http://www.experts-exchange.com/Microsoft/Development/MS-SQL-Server/SSIS/A_9150-Loading-XML-Using-SSIS.html) I showed you how the XML Source component can be used to load XML files into a SQL Server database, us…
Performance in games development is paramount: every microsecond counts to be able to do everything in less than 33ms (aiming at 16ms). C# foreach statement is one of the worst performance killers, and here I explain why.
Internet Business Fax to Email Made Easy - With  eFax Corporate (http://www.enterprise.efax.com), you'll receive a dedicated online fax number, which is used the same way as a typical analog fax number. You'll receive secure faxes in your email, f…
Many functions in Excel can make decisions. The most simple of these is the IF function: it returns a value depending on whether a condition you describe is true or false. Once you get the hang of using the IF function, you will find it easier to us…

867 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

22 Experts available now in Live!

Get 1:1 Help Now