0

我有一个返回数组列表的类,但是当我阅读它时,我想在页面中写入值。

我有这堂课:

        public ArrayList users(string table)
        {
            ArrayList list = new ArrayList();
            foreach (DataRow item in com.Execute("select * from " + table + ";").Rows)
            {
                list.Add(item["id"].ToString());
                list.Add(item["mail"].ToString());
                list.Add(item["data"].ToString());
            }

            return list;
        }

Page_Load

loadUsersNewsletter lun = new loadUsersNewsletter();
String[] myArr = (String[])lun.users("newsletter").ToArray(typeof(string));
foreach (Object o in myArr)
{
    load.Controls.Add(new LiteralControl("<tr><td>" + o + "</td><td>" + o + "</td></tr>"));
    ...
}

如何按索引或其他方式读取值,以免重复值?如果有其他解决方案,请告诉我。

4

3 回答 3

1

你应该改变users方法,如:

public List<string[]> users(string table)
    {
        List<string[]> list = new List<string[]>();
        foreach (DataRow item in com.Execute("select * from " + table + ";").Rows)
        {
            list.Add(new string[]{item["id"].ToString(), item["mail"].ToString(), 
                                                    item["data"].ToString()});
        }

        return list;
    }

和 :

loadUsersNewsletter lun = new loadUsersNewsletter();
List<string[]> myArr = lun.users("newsletter");
foreach (string[] o in myArr)
 {
   load.Controls.Add(new LiteralControl("<tr><td>" + o[0] + "</td><td>" + o[1] 
                                        + "</td><td>" + o[2] + "</td></tr>"));
 }
于 2013-02-23T18:15:27.007 回答
0

尝试使用Distinct,像这样:

foreach (var o in myArr.Distinct())
{
    load.Controls.Add(new LiteralControl("<tr><td>" + o + "</td><td>" + o + "</td></tr>"));
    ...
}

或者,如果您正在从数据库加载数据,您可能会考虑在数据库服务器上执行此操作,即,而不是这样:

"select * from table"

试试这个 :

"select distinct * from table"
于 2013-02-23T17:53:59.160 回答
-1

如果要消除重复项,可以使用此代码。

String[] myArr = (String[])lun.users("newsletter").ToArray(typeof(string));
    List<string> Content=new List<string>();
    foreach (Object o in myArr)
    {
        if(Content.Contains(o.ToString()))
    continue;
    Content.Add(o.ToString());
        load.Controls.Add(new LiteralControl("<tr><td>" + o + "</td><td>" + o + "</td></tr>"));
        ...
    }
于 2013-02-23T17:55:27.613 回答