Подтвердить что ты не робот

Как проверить, является ли строковое значение в списке Enum?

В моей строке запроса у меня есть возрастная переменная ?age=New_Born.

Есть ли способ проверить, является ли это строковое значение New_Born в моем списке Enum

[Flags]
public enum Age
{
    New_Born = 1,
    Toddler = 2,
    Preschool = 4,
    Kindergarten = 8
}

Я мог бы использовать оператор if прямо сейчас, но если список Enum становится больше. Я хочу найти лучший способ сделать это. Я думаю об использовании Linq, просто не уверен, как это сделать.

4b9b3361

Ответ 1

Вы можете использовать:

 Enum.IsDefined(typeof(Age), youragevariable)

Ответ 2

Вы можете использовать метод Enum.TryParse:

Age age;
if (Enum.TryParse<Age>("New_Born", out age))
{
    // You now have the value in age 
}

Ответ 3

Вы можете использовать метод TryParse, который возвращает true, если он успешный:

Age age;

if(Enum.TryParse<Age>("myString", out age))
{
   //Here you can use age
}

Ответ 4

Чтобы проанализировать возраст:

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, поскольку имеет несколько значений.

Ответ 5

Вы должны использовать 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
}

Ответ 6

Я знаю, что это старый поток, но здесь немного другой подход с использованием атрибутов в 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; }
}