LINQ to XML query - код возвращает только первый элемент - PullRequest
0 голосов
/ 26 сентября 2010

Я потратил довольно много часов, читая и изучая LINQ to XML , но здесь я наткнулся на контрольно-пропускной пункт.Вот пример моего XML-файла:

<project>
    <project_number>20071234</project_number>
    <project_name>ProjectA</project_name>
    <project_unc>\\fileserver1\projects\</project_unc>
    <contract>
        <full_name>Contract 00 Project1</full_name>
        <directory_name>00_Project1</directory_name>
    </contract>
    <contract>
        <full_name>Contract 01 Project2</full_name>
        <directory_name>01_Project2</directory_name>
    </contract>
</project>
<project>
    <project_number>20081234</project_number>
    <project_name>ProjectB</project_name>
    <project_unc>\\fileserver2\projects\</project_unc>
    <contract>
        <full_name>Contract 00 Project3</full_name>
        <directory_name>00_project3</directory_name>
    </contract>
    <contract>
        <full_name>Contract 01 Project4</full_name>
        <directory_name>01_project4</directory_name>
    </contract>
</project>

В моей программе кто-то собирается выбрать номер_проекта из выпадающего списка.Когда они это сделают, он вызовет запрос к XML-файлу, который будет захватывать этот номер_проекта и искать все контракты.

XDocument XDoc = null;
XDoc = XDocument.Load("projects.xml");
List<ProjectContract> pc = new List<ProjectContract>(); //Created in class
var query = from xml in XDoc.Descendants("project") where (string)xml.Element("project_number") == dropDown1.SelectedItem
             select new ProjectContract
             {
                 fullname = (string)xml.Element("contract").Element("full_name"),
                 dirname = (string)xml.Element("contract").Element("directory_name")
             };
pc = query.ToList();

Я, очевидно, здесь что-то делаю не так;Я просто не вижу что.Этот код возвращает только первую позицию контракта из любого проекта, но не из обоих.

Ответы [ 2 ]

1 голос
/ 26 сентября 2010

Вам необходимо получить все контакты-потомки элемента проекта, а затем выбрать новый контакт проекта для каждого из них.Вы можете изменить свой запрос следующим образом, и он будет работать так, как вы ожидаете:

        var query = from xml in XDoc.Descendants("project")
                    from contactxml in xml.Descendants("contract")
                    where (string)xml.Element("project_number") 
                                                  == dropDown1.SelectedItem
                    select new ProjectContract
                    {
                        fullname = (string)contactxml.Element("full_name"),
                        dirname = (string)contactxml.Element("directory_name")
                    };

(хотя я бы использовал xml.Element("whatever").Value вместо xml.Element("whatever"). Просто выглядит лучше.)

0 голосов
/ 26 сентября 2010

Попробуйте это

var query = from contract in XDoc.Descendants("contract")
            where contract.Parent.Element("project_number").Value == dropDown1.SelectedItem
            select new ProjectContract
                     {
                         fullname = (string)xml.Element("contract").Element("full_name"),
                         dirname = (string)xml.Element("contract").Element("directory_name")
                     };
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...