Groups | Blog | Home
all groups > dotnet framework > june 2006 >

dotnet framework : Escaping backslashes in XPath (C#)



chris
6/30/2006 8:37:02 AM
I have an XML file which have nodes that contain filepaths,
e.g.<path>c:\SomeDirectory\SomeFile.txt</path>

I'm using an XmlDocument and XPath query to try and find a node
XmlDocument doc = new XmlDocument();
doc.LoadXml(File.ReadAllText(xmlFilePath));

string somePath = @"c:\SomeDirectory\SomeFile.txt";
string query = "node1/node2[Path='" + somePath + "']";
XmlNodeList nodes = doc.SelectNodes(query);

The problem is, query becomes
"node1/node2[Path='c:\\SomeDirectory\\SomeFile.txt']" (Note the double quotes
due to the escaping of the backslashes). Obviously this doesn't match the XML
node in question. How do I work around this? (I don't want to use double
Chris Chilvers
7/1/2006 2:03:45 AM
On Fri, 30 Jun 2006 08:37:02 -0700, chris
[quoted text, click to view]

I'm not sure what your problem is here. Unless you're doing something
else to somePath then it should not have double backslashes. Any escape
characters are resolved when the application is compiled.

==========

using System;

namespace Test {
public class Test {
public static void Main() {
string somePath = @"c:\SomeDirectory\SomeFile.txt";
string query = "node1/node2[Path='" + somePath + "']";

Console.WriteLine(query);
Console.ReadKey();
}
}
}

==========

Outputs:
Göran Andersson
7/2/2006 12:00:00 AM
Why do you think that the query looks like that? Do you look at the
contenst of the variable using the debug mode in Visual Studio? Then
it's shown as it would be written in code, so the double backslashes
means a single backslash.

[quoted text, click to view]
AddThis Social Bookmark Button