空引用异常 - 使用Element和XPath的{XDocument

时间:2015-07-21 07:06:25

标签: c# xml xpath linq-to-xml

我从数据库中以字符串的形式获取一些XML数据。数据在数据库中保存为ntext。

从数据库获取数据不是问题。问题是稍后,当我想处理xml中的数据时。我将一个字符串加载到xDocument中。

我想首先获得所有者值。但我得到一个nullreference异常,这意味着我没有写出我假设的正确的Xpath。

写作" ./所有者"不起作用。写作" /./所有者"不起作用然后我得到一个XML异常。

我从XMLDocument开始,但认为我遇到了命名空间问题。开始阅读,看起来像使用xDocument更好。 正如您也可以通过我的代码看到的那样,我尝试以两种方式获取所有者值,都失败了。

我的XML看起来有点像这样:

    <Container xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="DM">
<IsConsigned>false</IsConsigned>
<LockState>Unlocked</LockState>
<SourceType i:nil="true" />
<Id>04216194-4f62-47ee-ab21-c1053d01bf1e</Id>
<Owner>IN</Owner>
<Created>2012-08-21T09:29:10.528321+02:00</Created>
</Container>

我的代码:

      class Program
{
   static SqlConnection conn = new SqlConnection();
   static XDocument xml = new XDocument();

    static void Main(string[] args)
    {
        using (conn)
        {
            conn.ConnectionString = Properties.Settings.Default.connectionString;
            //connection.Open();
            conn.Open();
            SqlDataReader reader = GetDataFromDatabase();

            if (reader.HasRows)
            {

                while (reader.Read())
                {
                    string xmlFile = reader.GetSqlString(0).ToString();
                    HandleData(xmlFile);
                }
            }
            else
            {
                Console.WriteLine("No rows found.");
            }
            reader.Close();
        }
    }

    public static void HandleData(string xmlIn)
    {

        xml = XDocument.Parse(xmlIn);
        XElement xmlElement = xml.Root;
        string test1 = xml.Element("Owner").Value.ToString();
        string test = xmlElement.Element("Owner").Value.ToString();
    }

    }

2 个答案:

答案 0 :(得分:2)

这不是使用XmlDocumentXDocument的问题。您的XML具有默认命名空间,这是一个没有前缀声明的命名空间,在这里:

xmlns="DM"

与前缀为i的广告形成鲜明对比:xmlns:i="http://www.w3.org/2001/XMLSchema-instance"。请注意,不仅声明了默认名称空间声明的元素,而且所有后代元素都隐式地继承祖先默认名称空间,除非另有指定(使用显式名称空间前缀或指向不同名称空间uri的本地默认名称空间)。

您可以使用"XNamespace"+"element's local name"的组合在命名空间中为引用元素形成限定名,例如:

var xmlIn = @"<Container xmlns:i='http://www.w3.org/2001/XMLSchema-instance' xmlns='DM'>
<IsConsigned>false</IsConsigned>
<LockState>Unlocked</LockState>
<SourceType i:nil='true' />
<Id>04216194-4f62-47ee-ab21-c1053d01bf1e</Id>
<Owner>IN</Owner>
<Created>2012-08-21T09:29:10.528321+02:00</Created>
</Container>";
var xml = XDocument.Parse(xmlIn);
XNamespace d = "DM";
string owner = xml.Root.Element(d+"Owner").Value;
Console.WriteLine(owner);
string id = xml.Root.Element(d+"Id").Value;
Console.WriteLine(id);

Dotnetfiddle Demo

输出

IN
04216194-4f62-47ee-ab21-c1053d01bf1e

旁注:

答案 1 :(得分:0)

请在http://www.w3schools.com/xpath/default.asp了解有关XPath的更多信息。

您的解决方案可在此处找到:https://dotnetfiddle.net/Aflm8t