How about just LINQ to XML?
Given this:
var xml = "<ss:demo>\r\n<ss:Name>\r\n <ss:FirstName>First</ss:FirstName>\r\n <ss:SecondName>" +
"Second</ss:SecondName>\r\n</ss:Name>\r\n<ss:country code=\"IN\">India</ss:country>\r\n</ss" +
":demo>";
(Note I had to wrap IN in quotes as such "IN")
Declare some namespaces and read it in:
var mngr = new XmlNamespaceManager( new NameTable() );
mngr.AddNamespace( "ss", "urn:ignore" ); // or proper URL
var parserContext = new XmlParserContext(null, mngr, null, XmlSpace.None, null);
If reading from a string as above:
var txtReader = new XmlTextReader( xml, XmlNodeType.Element, parserContext );
If reading from a file instead:
var txtReader = new XmlTextReader( new FileStream(filename, FileMode.Open), XmlNodeType.Element, parserContext );
Then load:
var ele = XElement.Load( txtReader );
ele contains everything you need.
INisn't in quotes in thecodeattribute. My answer expects the second to be fixed and works regardless of the first.