繁体   English   中英

在Textbox C#中显示从组合框选择的XML数据

[英]Displaying XML data selected from Combobox in Textbox C#

您好,我正在学习C#,并试图在组合框中选择它之后,以相同的形式在Text1的文本框中显示User1.xml中的xml信息。

我已经设法使用此代码用名称标签填充组合框。 (以便可以选择用户名)

private void Form1_Load(object sender, EventArgs e)
{
   XmlDocument sFor = new XmlDocument();
   sFor.Load(Path.GetFullPath("User1.xml"));
   XmlNodeList SearchList = sFor.SelectNodes("employee/user/name");
   foreach (XmlNode Search in SearchList)
   {
      comboBox1.Items.Add(Search.InnerText);
   }

}

这样就格式化了XML

<employee>
    <user>
    <name>John Smith</name>
    <department>PAI</department>
    <manager>MD</manager>
    <hours>full-time</hours>
    <leave>940</leave>
    </user>
</employee>

在组合框中选择后,我将如何(使用linq或xmlreader或其他方式)在textBox2中显示信息?

谢谢。

如果这可以帮助您

XDocument doc = XDocument.Load(Path.GetFullPath("User1.xml"));

var rows = doc.Descendants("employee").Descendants("user").Select(el => new()
{
  department = el.Element("department").Value,
  manager = el.Element("manager").Value,
  hours = el.Element("hours").Value,
  leave = el.Element("leave").Value,
});

或从DataSet这样

DataSet ds = new DataSet();
ds.ReadXmlSchema(new StreamReader("User1.xml"));
ds.ReadXml(new StreamReader("User1.xml"));

我对DataGridView进行了类似的操作以寻找“城市”。 输入字段是Textbox1.Text。 我希望这不是矫kill过正。 功劳归于Stack在这里的海报,向我展示了如何做! 我先提取了特定数据,然后将其加载到列表中。 最后,使列表成为DGV的数据源。 这可能适合组合框...是吗?

<TaxTbl>
  <TaxSite>
    <Location>Axx</Location>
    <Address>xxx</Address>
    <City>aaa</City>
    <State> st</State>
    <Zip>xxx</Zip>
  </TaxSite>
  <TaxSite>
    <Location>Bxxx</Location>
    <Address>xxx</Address>
    <City>xxx</City>
    <State> st</State>
    <Zip>xxx</Zip>
  </TaxSite>
</TaxTbl>






 var xdoc = XDocument.Load("C:\\Users\\Harley\\desktop\\outfile.xml");



var NewDoc = new XDocument(new XElement("TaxTbl",
             from anEntry in xdoc.Element("TaxTbl").Elements("TaxSite")
             where anEntry.Element("City").Value.Contains(textBox1.Text)
             select anEntry));



var MyList =
                    (from bEntry in NewDoc.Descendants("TaxSite")
                     select new
                     {
                         Location = bEntry.Element("Location").Value,
                         Address = bEntry.Element("Address").Value,
                         City = bEntry.Element("City").Value,
                         State = bEntry.Element("State").Value,
                         Zip = bEntry.Element("Zip").Value
                     }).ToList();


 cityDGV.DataSource = MyList.ToList();

暂无
暂无

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

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