在循环中创建动态名称

时间:2012-05-31 10:32:09

标签: c# asp.net .net

for (int i = 0; i < DT1.Rows.Count; i++)
{
    PivotGridField field + i = new PivotGridField();
}

当然,这段代码不起作用,但如何让它以这种方式工作,因为我需要创建未知数量的字段。

谢谢!

5 个答案:

答案 0 :(得分:3)

您无法动态创建字段(或在本例中为变量)。你可以做的是有一个数组/列表/类似的东西:

PivotGridField[] fields = new PivotGridField[DT1.Rows.Count];
for (int i = 0; i < DT1.Rows.Count; i++)
{
    fields[i] = new PivotGridField();
}

现在,只要您想要“字段n”,请使用fields[n]

答案 1 :(得分:3)

你可以用不同的方式做到这一点。首先,您可以使用像Marc建议的数组。另一种方法是使用字典:

Dictionary<string,PivotGridField> fields = new Dictionary<string, PivotGridField>();
for (int i = 0; i < DT1.Rows.Count; i++)
{
    fields["field"+i] = new PivotGridField();
}

fields["field1"] = ...

第三种方法是使用ExpandoObject

dynamic fields = new ExpandoObject();
for (int i = 0; i < DT1.Rows.Count; i++)
{
    ((IDictionary<String, Object>) fields).Add("field" + i, new PivotGridField());
}

然后,您可以像访问真实成员字段一样访问您的字段:

fields.field1 = ...
fields.field2 = ...

答案 2 :(得分:0)

不,在C#中,您无法动态生成变量名称。

但您可以设置各种字段属性的值:

for (int i = 0; i < DT1.Rows.Count; i++)
{
    PivotGridField field = new PivotGridField();
    field.Name = "Name " + i;
    grid.Fields.Add(field);
}

答案 3 :(得分:0)

也许你可以创建一个PivotGridField类型的列表,并在每次迭代时添加到列表中。如果PivotGridField的某个属性类似于“name”,则可以将其设置为“field”+ i。

答案 4 :(得分:0)

您可以在C#中动态创建字段/属性,但仅适用于特定类型的对象。使用ExpandoObject,您可以执行以下操作:

    ExpandoObject expando = new ExpandoObject();
    IDictionary<string, object> expandoAsDict = expando as IDictionary<string, object>;
    expando.Add("MyTotallyNewProperty", "MyTotallyNewPropertyValue");
    Console.WriteLine(expando.MyTotallyNewProperty); //this will print "MyTotallyNewPropertyValue"

您可以通过继承DynamicObject来自定义动态对象的性质。阅读here

那就是说,在你的情况下,你应该使用其他建议。动态对象应该只在需要时使用,在你的情况下,动态数据结构可以很好地完成这个工作。请记住,仅仅因为“&#39; field&#39;出现在规范中,并不意味着您需要使用字段的C#概念来实现它。

注意:DynamicObject仅存在于.NET 4.0或更高版本中。在以前的版本中没有方便的方法。

相关问题