简体   繁体   English

在c#中检索xml文件中具有相同关键字的其他数据

[英]retrieve the other data that have the same keyword in xml file in c#

i saved all my data in xml file. 我将所有数据保存在xml文件中。

<myself>
  <name>sara</name>
  <age>20</age>
  <gender>female</gender>
</myself>
<myself>
   <name>bob</name>
   <age>29</age>
   <gender>male</gender>
</myself>

and there is search box which user can search all the data based on the types and keyword. 并且有搜索框,用户可以根据类型和关键字搜索所有数据。 for this, i am putting two types;by name and by gender. 为此,我提出了两种类型:名称和性别。

so once the user choose name and put the keyword is sara , the output will display everything about her. 因此,一旦用户选择名称并将关键字设置为sara ,输出将显示有关她的所有内容。

example of output should be display 应该显示输出的例子

sara
20
female

for this output, i make the it to display with each own textbox. 对于此输出,我使用每个自己的文本框显示它。 there have 3 textbox title name, age and gender. 有3个文本框标题名称,年龄和性别。

XmlDocument xml = new XmlDocument();            
        xml.Load("C:\\Users\\HDAdmin\\Documents\\Fatty\\SliceEngine\\SliceEngine\\bin\\Debug\\saya.xml");
        XmlNodeList xnList = xml.SelectNodes("/myself");            
        foreach (XmlNode xn in xnList)
        {                
            string name = xn.InnerText;                
            nameBox.Text = nameBox.Text + " " + name;
            string age = xn.InnerText;                
            ageBox.Text = ageBox.Text + " " + age;
            string gender = xn.InnerText;                
            genderBox.Text = genderBox.Text + " " + gender;
        }

i have tried using XmlNodeList xnList = xml.SelectNodes("/myself"); 我尝试过使用XmlNodeList xnList = xml.SelectNodes("/myself"); but it will print out everything about sara and bob. 但它会打印出关于sara和bob的一切。

so im guessing i could make the xml file to be like 所以我猜我可以让xml文件像

<name>sara
   <gender>female
       <age>20</age>
   </gender>
</name>

but i think this cannot work out. 但我认为这无法解决。 is there a way for this? 这有什么办法吗?

this is the way to save the data. 这是保存数据的方法。

XmlDocument xmlDoc = new XmlDocument();
                xmlDoc.Load("C:\\Users\\HDAdmin\\Documents\\SliceEngine\\SliceEngine\\bin\\Debug\\saya.xml");
                XmlElement contentElement = xmlDoc.CreateElement("myself");

                XmlElement nameEl = xmlDoc.CreateElement("name");
                XmlText xmlText = xmlDoc.CreateTextNode(berjaya[1]);
                nameEl.AppendChild(xmlText);
                contentElement.AppendChild(nameEl);
                xmlDoc.DocumentElement.AppendChild(contentElement);

                XmlElement ageEl = xmlDoc.CreateElement("age");
                ageEl.InnerText = berjaya[3];
                contentElement.AppendChild(ageEl);
                xmlDoc.DocumentElement.AppendChild(contentElement);

                XmlElement genEl = xmlDoc.CreateElement("gender");
                genEl.InnerText = berjaya[39];
                contentElement.AppendChild(genEl);
                xmlDoc.DocumentElement.AppendChild(contentElement);

++++++++++++====PROBLEM SOLVED====++++++++++++++++++++ ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

thanks for the help. 谢谢您的帮助。 this have been resolved. 这已经解决了。 I am using answer given by @horgh. 我正在使用@horgh给出的答案。

so here is what i learned. 所以这就是我学到的东西。

1- in my xml file, i need to have main tag. 1-在我的xml文件中,我需要有主标签。

2- using if loop to retrieve data from the keyword. 2-使用if循环从关键字中检索数据。

and to view the other data, its going to be like this: 并查看其他数据,它将是这样的:

string name = xn.OfType<XmlNode>().FirstOrDefault(n => n.Name == "name").FirstChild.Value;
            if (name == "sara")
            {
                nameBox.Text = nameBox.Text + " " + name;
                string age = xn.OfType<XmlNode>().FirstOrDefault(n => n.Name == "age").FirstChild.Value;
                ageBox.Text = ageBox.Text + " " + age;
                string gender = xn.OfType<XmlNode>().FirstOrDefault(n => n.Name == "gender").FirstChild.Value;
                genderBox.Text = genderBox.Text + " " + gender; 

            }

for more information you can see below. 有关详细信息,请参阅下文。 Thanks again for all the help given. 再次感谢所有帮助。

here is example 这是一个例子

    [Test]
    public void Test()
    {
        XElement root = XElement.Load(@"C:\Data.xml");
        XElement person = FindByName(root, "sara");
        if (person == null)
        {
            return;
        }
        Console.WriteLine("Name: {0}, Age: {1}, Gender: {2}",
                          person.Element("name").Value,
                          person.Element("age").Value,
                          person.Element("age").Value);
    }

    private static XElement FindByName(XContainer root, string name)
    {
        return root.Descendants()
            .Where(x => x.Name.LocalName == "name" && x.Value == name)
            .Select(x => x.Parent)
            .FirstOrDefault();
    }

Xml file: root element has been added Xml文件:已添加根元素

<root>
  <myself>
    <name>sara</name>
    <age>20</age>
    <gender>female</gender>
  </myself>
  <myself>
    <name>bob</name>
    <age>29</age>
    <gender>male</gender>
  </myself>
</root>

Console out put: 控制台输出:

Name: sara, Age: 20, Gender: 20

Suggestion: 建议:

  • FindByName may be should return more then 1 element, ie List<XElement> FindByName可能应该返回多于1个元素,即List<XElement>
  • Add Person class with properties Name, Age, Gender 添加具有属性Name,Age,Gender的Person类

At first, I had an error, saying that the xml has no root element, so I added root tag: 起初,我有一个错误,说xml没有root元素,所以我添加了root标签:

<main>
 <myself>
  <name>sara</name>
  <age>20</age>
  <gender>female</gender>
</myself>
<myself>
  <name>bob</name>
  <age>29</age>
  <gender>male</gender>
</myself>

Than I added a check for the requested name, ie "sara": 比我添加了对所请求名称的检查,即“sara”:

if (name == "sara")

So, the resulting code is: 因此,生成的代码是:

        XmlDocument xml = new XmlDocument();
        xml.Load("1.xml");
        XmlNodeList xnList = xml.SelectNodes("/main/myself");
        foreach (XmlNode xn in xnList)
        {
            string name = xn.OfType<XmlNode>().FirstOrDefault(n => n.Name == "name").FirstChild.Value;
            if (name == "sara")
            {
                nameBox.Text = nameBox.Text + " " + name;
                string age = xn.OfType<XmlNode>().FirstOrDefault(n => n.Name == "age").FirstChild.Value;
                ageBox.Text = ageBox.Text + " " + age;
                string gender = xn.OfType<XmlNode>().FirstOrDefault(n => n.Name == "gender").FirstChild.Value;
                genderBox.Text = genderBox.Text + " " + gender;                                        
            }
        }

And the output is: 输出是:

sara
20
female

How about 怎么样

XmlDocument xml = new XmlDocument();            
xml.Load("YourFilePath");        
foreach(var xml in doc.Elements("rootelement").Elements("myself").Elements("name")) 
{
     //Do what you want.
}

The XPath you specified will select all elements called "myself" which correctly returns both the data for sara and bob. 你指定的XPath将选择所有名为“我自己”的元素,它们正确地返回sara和bob的数据。

Try using "//myself[name=sara]" in your SelectNodes call. 尝试在SelectNodes调用中使用“// myself [name = sara]”。 It should only return the myself elements that have name with a value of sara. 它应该只返回名称值为sara的我自己的元素。

PS: I would also suggest renaming your myself elements to Person or something like that. PS:我还建议将自己的元素重命名为Person或类似的东西。 :) :)

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM