我有一个具有Description属性的枚举,如下所示:
public enum MyEnum
{
Name1 = 1,
[Description("Here is another")]
HereIsAnother = 2,
[Description("Last one")]
LastOne = 3
}
我发现这段代码用于基于Enum检索描述
public static string GetEnumDescription(Enum value)
{
FieldInfo fi = value.GetType().GetField(value.ToString());
DescriptionAttribute[] attributes = fi.GetCustomAttributes(typeof(DescriptionAttribute), false) as DescriptionAttribute[];
if (attributes != null && attributes.Any())
{
return attributes.First().Description;
}
return value.ToString();
}
这允许我编写如下代码:
var myEnumDescriptions = from MyEnum n in Enum.GetValues(typeof(MyEnum))
select new { ID = (int)n, Name = Enumerations.GetEnumDescription(n) };
我想做的是,如果我知道枚举值(例如1)-我怎么能检索描述?换句话说,如何将整数转换为“Enum值”传递给我的GetDescription方法?
我把代码从接受的答案放在一个通用的扩展方法中,所以它可以用于各种对象:
public static string DescriptionAttr<T>(this T source)
{
FieldInfo fi = source.GetType().GetField(source.ToString());
DescriptionAttribute[] attributes = (DescriptionAttribute[])fi.GetCustomAttributes(
typeof(DescriptionAttribute), false);
if (attributes != null && attributes.Length > 0) return attributes[0].Description;
else return source.ToString();
}
使用像原始帖子中那样的枚举,或者任何其他属性被Description属性装饰的类,代码可以像这样使用:
string enumDesc = MyEnum.HereIsAnother.DescriptionAttr();
string classDesc = myInstance.SomeProperty.DescriptionAttr();
更新
不再维护Unconstrained Melody库;不再支持Enums.NET。
在枚举。NET你会使用:
string description = ((MyEnum)value).AsString(EnumFormat.Description);
最初的发布
我在Unconstrained Melody中以一种通用的、类型安全的方式实现了这一点——你会使用:
string description = Enums.GetDescription((MyEnum)value);
这样的:
确保(使用泛型类型约束)值确实是枚举值
避免当前解决方案中的装箱
缓存所有的描述,以避免在每个调用上使用反射
有一堆其他的方法,包括从描述中解析值的能力
我意识到核心答案只是从int转换到MyEnum,但如果你做了很多枚举工作,值得考虑使用Unconstrained Melody:)
我把代码从接受的答案放在一个通用的扩展方法中,所以它可以用于各种对象:
public static string DescriptionAttr<T>(this T source)
{
FieldInfo fi = source.GetType().GetField(source.ToString());
DescriptionAttribute[] attributes = (DescriptionAttribute[])fi.GetCustomAttributes(
typeof(DescriptionAttribute), false);
if (attributes != null && attributes.Length > 0) return attributes[0].Description;
else return source.ToString();
}
使用像原始帖子中那样的枚举,或者任何其他属性被Description属性装饰的类,代码可以像这样使用:
string enumDesc = MyEnum.HereIsAnother.DescriptionAttr();
string classDesc = myInstance.SomeProperty.DescriptionAttr();
不能简单地以通用的方式做到这一点:只能将整数转换为特定类型的枚举。正如Nicholas所展示的,如果您只关心一种类型的枚举,这是一个微不足道的强制转换,但如果您想编写一个可以处理不同类型枚举的泛型方法,事情就会变得有点复杂。你想要的方法如下:
public static string GetEnumDescription<TEnum>(int value)
{
return GetEnumDescription((Enum)((TEnum)value)); // error!
}
但这会导致编译器错误,“int不能被转换为TEnum”(如果你绕过这个问题,“TEnum不能被转换为Enum”)。所以你需要通过向object插入类型转换来欺骗编译器:
public static string GetEnumDescription<TEnum>(int value)
{
return GetEnumDescription((Enum)(object)((TEnum)(object)value)); // ugly, but works
}
你现在可以调用这个来获取手边任何类型枚举的描述:
GetEnumDescription<MyEnum>(1);
GetEnumDescription<YourEnum>(2);