List.count=0 当从 XML 文件获取数据到 List() 时

本文关键字:List 数据 获取 文件 count 当从 XML | 更新日期: 2023-09-27 18:36:20

我有一个user.xml文件,如下所示:

<?xml version="1.0" encoding="utf-8"?>
<myXML>
  <RealName>Nguyen Van A</RealName>
  <Email>vyclarks@gmail.com</Email>
  <Phone>2165421</Phone>
  <Address>Ho Chi Minh</Address>
  <Link1>dtvt</Link1>
  <Link2></Link2>
  <Link3></Link3>
</myXML>

我有代码可以从 xml 文件中获取数据:

public class user
    {
        public string realname { get; set; }
        public string email { get; set; }
        public string phone { get; set; }
        public string address { get; set; }
        public string link1 { get; set; }
        public string link2 { get; set; }
        public string link3 { get; set; }
    }
public void getUser()
    {
            List<user> us = (
                      from e in
                      XDocument.Load("user.xml").Root.Elements("myXML")
                      select new user
                      {
                        realname = (string)e.Element("RealName"),
                        email = (string)e.Element("Email"),
                        phone = (string)e.Element("Phone"),
                        address = (string)e.Element("Address"),
                        link1 = (string)e.Element("Link1"),
                        link2 = (string)e.Element("Link2"),
                        link3 = (string)e.Element("Link3")
                      }
                      ).ToList();
//get data from list to label
            lblrealname.Text = us[0].ToString();
            lblmail.Text = us[1].ToString();
            lblphone.Text = us[2].ToString();
            lbladd.Text = us[3].ToString();
            lbllink1.Text = us[4].ToString();
            lbllink2.Text = us[5].ToString();
            lbllink3.Text = us[6].ToString();
    }

但是当我构建时,它有一个错误:lblrealname.Text = profiles[0].ToString();这是内容:Index was out of range. Must be non-negative and less than the size of the collection.

然后我调试,us.count = 0 --->我想知道我上面的代码是否有一些错误,所以列表中没有项目us.

帮助!!我找不到哪里有问题,有没有更好的方法可以从该 xml 文件中获取数据。

List.count=0 当从 XML 文件获取数据到 List() 时

拆分 UI 和数据访问逻辑。使方法返回对象User而不是 null。因此,您的 xml 中只有一个根,您无需编写返回用户列表的查询 - 只需直接访问根节点即可。还可以将 PascalCase 用于类型名称、方法和属性:

public User GetUser()
{
    var root = XDocument.Load("user.xml").Root;
    return new User {
         RealName = (string)root.Element("RealName"),
         Email = (string)root.Element("Email"),
         Phone = (string)root.Element("Phone"),
         Address = (string)root.Element("Address"),
         Link1 = (string)root.Element("Link1"),
         Link2 = (string)root.Element("Link2"),
         Link3 = (string)root.Element("Link3")
    };
}

在 UI 上显示用户:

public void DisplayUser(User user)
{
    lblrealname.Text = user.RealName;
    lblmail.Text = user.Email;
    lblphone.Text = user.Phone;
    lbladd.Text = user.Address;
    lbllink1.Text = user.Link1;
    lbllink2.Text = user.Link2;
    lbllink3.Text = user.Link3;
}

总之:

var user = GetUser();
DispalylUser(user);

下一行

from e in XDocument.Load("user.xml").Root.Elements("myXML")

结果为 0,因为 <myXML> 根,并且看起来不包含任何嵌套<myXML>


以下应该有效。

from e in XDocument.Load("user.xml").Elements("myXML")

如果你不需要枚举,你可以只取根

var element = XDocument.Load("user.xml").Root;
相关文章: