Ответ 1
Вы можете использовать:
Enum.IsDefined(typeof(Age), youragevariable)
В моей строке запроса у меня есть возрастная переменная ?age=New_Born
.
Есть ли способ проверить, является ли это строковое значение New_Born
в моем списке Enum
[Flags]
public enum Age
{
New_Born = 1,
Toddler = 2,
Preschool = 4,
Kindergarten = 8
}
Я мог бы использовать оператор if прямо сейчас, но если список Enum становится больше. Я хочу найти лучший способ сделать это. Я думаю об использовании Linq, просто не уверен, как это сделать.
Вы можете использовать:
Enum.IsDefined(typeof(Age), youragevariable)
Вы можете использовать метод Enum.TryParse:
Age age;
if (Enum.TryParse<Age>("New_Born", out age))
{
// You now have the value in age
}
Вы можете использовать метод TryParse, который возвращает true, если он успешный:
Age age;
if(Enum.TryParse<Age>("myString", out age))
{
//Here you can use age
}
Чтобы проанализировать возраст:
Age age;
if (Enum.TryParse(typeof(Age), "New_Born", out age))
MessageBox.Show("Defined"); // Defined for "New_Born, 1, 4 , 8, 12"
Чтобы узнать, определено ли это:
if (Enum.IsDefined(typeof(Age), "New_Born"))
MessageBox.Show("Defined");
В зависимости от того, как вы планируете использовать перечисление Age
, флаги могут быть неправильными. Как вы, наверное, знаете, [Flags]
указывает, что вы хотите разрешить несколько значений (как в битовой маске). IsDefined
вернет false для Age.Toddler | Age.Preschool
, поскольку имеет несколько значений.
Вы должны использовать Enum.TryParse для достижения своей цели
Это пример:
[Flags]
private enum TestEnum
{
Value1 = 1,
Value2 = 2
}
static void Main(string[] args)
{
var enumName = "Value1";
TestEnum enumValue;
if (!TestEnum.TryParse(enumName, out enumValue))
{
throw new Exception("Wrong enum value");
}
// enumValue contains parsed value
}
Я знаю, что это старый поток, но здесь немного другой подход с использованием атрибутов в Enumerates, а затем вспомогательный класс для поиска нумерации, которая соответствует.
Таким образом, вы можете иметь несколько сопоставлений для одного перечисления.
public enum Age
{
[Metadata("Value", "New_Born")]
[Metadata("Value", "NewBorn")]
New_Born = 1,
[Metadata("Value", "Toddler")]
Toddler = 2,
[Metadata("Value", "Preschool")]
Preschool = 4,
[Metadata("Value", "Kindergarten")]
Kindergarten = 8
}
С моим вспомогательным классом, подобным этому
public static class MetadataHelper
{
public static string GetFirstValueFromMetaDataAttribute<T>(this T value, string metaDataDescription)
{
return GetValueFromMetaDataAttribute(value, metaDataDescription).FirstOrDefault();
}
private static IEnumerable<string> GetValueFromMetaDataAttribute<T>(T value, string metaDataDescription)
{
var attribs =
value.GetType().GetField(value.ToString()).GetCustomAttributes(typeof (MetadataAttribute), true);
return attribs.Any()
? (from p in (MetadataAttribute[]) attribs
where p.Description.ToLower() == metaDataDescription.ToLower()
select p.MetaData).ToList()
: new List<string>();
}
public static List<T> GetEnumeratesByMetaData<T>(string metadataDescription, string value)
{
return
typeof (T).GetEnumValues().Cast<T>().Where(
enumerate =>
GetValueFromMetaDataAttribute(enumerate, metadataDescription).Any(
p => p.ToLower() == value.ToLower())).ToList();
}
public static List<T> GetNotEnumeratesByMetaData<T>(string metadataDescription, string value)
{
return
typeof (T).GetEnumValues().Cast<T>().Where(
enumerate =>
GetValueFromMetaDataAttribute(enumerate, metadataDescription).All(
p => p.ToLower() != value.ToLower())).ToList();
}
}
вы можете сделать что-то вроде
var enumerates = MetadataHelper.GetEnumeratesByMetaData<Age>("Value", "New_Born");
И для полноты здесь есть атрибут:
[AttributeUsage(AttributeTargets.Field, Inherited = false, AllowMultiple = true)]
public class MetadataAttribute : Attribute
{
public MetadataAttribute(string description, string metaData = "")
{
Description = description;
MetaData = metaData;
}
public string Description { get; set; }
public string MetaData { get; set; }
}