Выберите значение узла XML по значению атрибута с несколькими уровнями - PullRequest
2 голосов
/ 18 октября 2011

Я стремлюсь получить значение в XML-коде дальше, чем в примерах, и с большим количеством атрибутов для рассмотрения.

Код XML:

<?xml version="1.0"?>
<mysqldump xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <database name="Members">
        <table_structure name="Logins">
            <field Field="ID" Type="int(100)" Null="NO" Key="PRI" Extra="auto_increment" Comment="" />
            <field Field="Username" Type="text" Null="YES" Key="" Extra="" Comment="" />
            <field Field="Password" Type="text" Null="YES" Key="" Extra="" Comment="" />
            <key Table="Logins" Non_unique="0" Key_name="PRIMARY" Seq_in_index="1" Column_name="ID" Collation="A" Cardinality="1" Null="" Index_type="BTREE" Comment="" />
            <options Name="Logins" Engine="MyISAM" Version="10" Row_format="Dynamic" Rows="1" Avg_row_length="20" Data_length="40" Max_data_length="281474976710655" Index_length="2048" Data_free="20" Auto_increment="3" Create_time="2011-10-14 19:30:57" Update_time="2011-10-14 19:32:21" Collation="latin1_swedish_ci" Create_options="" Comment="" />
        </table_structure>
        <table_data name="Logins">
            <row>
                <field name="ID">1</field>
                <field name="Username">MyName</field>
                <field name="Password">MyPassowrd</field>
            </row>
            <row>
                <field name="ID">2</field>
                <field name="Username">MyName2</field>
                <field name="Password">MyPassowrd2</field>
            </row>
        </table_data>
    </database>
</mysqldump>

Я пытаюсь добраться до 1, MyName и Password, чтобы затем ввести их в базу данных SQL.

У меня проблема с прохождением нескольких уровней:

<database name="Members">
    <table_data name="Logins">
        <row>
            <field name="ID">

Во всех примерах я нахожу только те, которые показывают 1 или 2 уровня.


Кажется, это работает,

XElement xe = XElement.Load("C:\\PATH.xml");

int count = xe.Descendants("row").Count();

var items = xe.Descendants("field").Where(n => (string)n.Attribute("name") == "ID").ToList();

var items2 = xe.Descendants("field").Where(n => (string)n.Attribute("name") == "Username").ToList();

var items3 = xe.Descendants("field").Where(n => (string)n.Attribute("name") == "Password").ToList();

             for (int i = 0; i < count; i++)
             {
                 string res = items[i].Value.ToString();
                 string res2 = items2[i].Value.ToString();
                 string res3 = items3[i].Value.ToString();
             }

У меня есть идентификатор, но теперь мне нужны все остальные элементы в его ряду.

То есть

if (id = 2)
{
    string name = username.value;
    string password = password.value;
}

где имя приведет к myName2, а пароль - MyPassword2.

Я не хочу помещать имена пользователей и пароли в список.

Еще один совет?

1 Ответ

0 голосов
/ 18 октября 2011

Попробуйте с LINQ to XML .

Здесь у вас есть учебник .

...