首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何从字符串返回枚举值?

从字符串返回枚举值,可以通过以下方法实现:

  1. 使用 switch 语句:
代码语言:csharp
复制
public enum MyEnum
{
    Value1,
    Value2,
    Value3
}

public static MyEnum GetEnumValue(string value)
{
    switch (value)
    {
        case "Value1":
            return MyEnum.Value1;
        case "Value2":
            return MyEnum.Value2;
        case "Value3":
            return MyEnum.Value3;
        default:
            throw new ArgumentException("Invalid value");
    }
}
  1. 使用 Enum.Parse 方法:
代码语言:csharp
复制
public static MyEnum GetEnumValue(string value)
{
    MyEnum result;
    if (Enum.TryParse(value, out result))
    {
        return result;
    }
    else
    {
        throw new ArgumentException("Invalid value");
    }
}
  1. 使用 Enum.Parse 方法并指定忽略大小写:
代码语言:csharp
复制
public static MyEnum GetEnumValue(string value)
{
    MyEnum result;
    if (Enum.TryParse(value, true, out result))
    {
        return result;
    }
    else
    {
        throw new ArgumentException("Invalid value");
    }
}
  1. 使用 Enum.Parse 方法并指定枚举类型:
代码语言:csharp
复制
public static Enum GetEnumValue(Type enumType, string value)
{
    Enum result;
    if (Enum.TryParse(enumType, value, out result))
    {
        return result;
    }
    else
    {
        throw new ArgumentException("Invalid value");
    }
}

注意:以上代码示例均使用 C# 语言编写。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

枚举很好用啊,为啥阿里不建议返回枚举

手册可以看出,定义和使用枚举,阿里开发手册都是支持的,但是为啥,返回就要反对了呢? 看看作者孤尽是怎么说的 由于升级原因,导致双方的枚举类不尽相同,在接口解析,类反序列化时出现异常。...可是为什么在返回和参数进行了区分呢,如果不兼容,那么两个都有问题,怎么允许参数可以有枚举。当时的考虑,如果参数也不能用,那么枚举几乎无用武之地了。...但如果是接口返回,就比较恶心了,因为解析回来的这个枚举,可能本地还没有,这时就会抛出序列化异常。...返回:Weather guess(参数),那么对方运算后,返回一个SNOWY,本地枚举里没有这个,傻眼了。 不过,另一位网友Brian的回答也很通俗易懂 枚举,就是把已知的全部罗列出来。...库版本升级后我支持了更多,你不知道情况下自然不会使用,反正我不支持的参数你不可能传递给我,所以作为输入,枚举简直就是安全保障。但作为返回,情况就反过来了。

2.1K20

枚举很好用啊,为啥阿里不建议返回枚举

我们先来看看阿里开发手册关于枚举使用的建议 ? 手册可以看出,定义和使用枚举,阿里开发手册都是支持的,但是为啥,返回就要反对了呢?...可是为什么在返回和参数进行了区分呢,如果不兼容,那么两个都有问题,怎么允许参数可以有枚举。当时的考虑,如果参数也不能用,那么枚举几乎无用武之地了。...但如果是接口返回,就比较恶心了,因为解析回来的这个枚举,可能本地还没有,这时就会抛出序列化异常。...返回:Weather guess(参数),那么对方运算后,返回一个SNOWY,本地枚举里没有这个,傻眼了。 不过,另一位网友Brian的回答也很通俗易懂 枚举,就是把已知的全部罗列出来。...库版本升级后我支持了更多,你不知道情况下自然不会使用,反正我不支持的参数你不可能传递给我,所以作为输入,枚举简直就是安全保障。但作为返回,情况就反过来了。

1.9K20
  • C++的函数如何返回多个

    本文介绍在C++语言中,使用一个函数,并返回两个及以上、同类型或不同类型的返回的具体方法。   ...对于C++语言而言,其不能像Python等语言一样在一个函数中返回多个返回;但是我们也会经常遇到需要返回两个甚至更多个的需求。...例如,如以下代码所示,我们定义了一个函数raster_to_series,函数类型为pair,表示这一函数的返回有两个,且两个返回的数据类型分别为double*...至此,我们即实现了通过一个C++函数返回两个返回的方法。   如果需要返回三个或更多的返回,则可以基于tuple(元组)这一数据结构,用类似于上述操作的方法来实现。...举一个例子,假如我们想通过一个函数返回三个返回,就需要将前述代码中函数的类型定义为tuple,将make_pair()函数更改为make_tuple(),且在调用函数时首先将返回赋给一个

    31910

    【说站】python函数如何返回多个

    python函数如何返回多个 一般情况下,一个函数只有一个返回,Python也是如此,只是Python函数可以通过返回列表或元组的方式将返回的多个保存到序列中,从而间接达到返回多个的目的。...说明 1、将要返回的多个提前存储在列表或元组中,然后函数返回该列表或元组。 2、函数直接返回多个,用逗号分隔,Python会自动将多个封装到一个元组,它的返回仍然是一个元组。...multi_return2():     return '张三', 12 print(multi_return()) result = multi_return2() print('multi_return2返回是...=,类型是=', result, type(result)) 以上就是python函数返回多个的方法,希望对大家有所帮助。

    2.2K20

    Go 100 mistakes之如何正确设置枚举中的零

    我们知道,在Go中会给定义的变量一个默认,比如int类型的变量默认是0。我们在定义枚举时,往往也会0开始定义。本文就解释如何区分是显示指定了变量的0还是因为确实字段而得到的默认。...这就是为什么我们在处理枚举时必须要小心的原因。让我们来看一些相关的实践以及如何避免一些常见的错误。...同时阅读者如果没有相关的阅读文档或者代码的话也不能猜出该函数返回的是什么。...itoa的0开始并每行增加1。...那我们应该如何区分请求中是传递的Monday还是就没有传递Weekday字段呢?这个问题和我们定义Weekday枚举的方式有关。实际上,Unknown是枚举的最后一个。因此,它的应该等于7.

    3.7K10

    CA1055:URI 返回不应是字符串

    规则 ID CA1055 类别 设计 修复是中断修复还是非中断修复 重大 原因 方法名称包含“uri”、“Uri”、“urn”、“Urn”、“url”或“Url”,且方法返回一个字符串。...如果存在匹配项,则规则假定该方法返回统一资源标识符 (URI)。 URI 的字符串表示形式容易导致分析和编码错误,并且可造成安全漏洞。 System.Uri 类以一种安全的方式提供这些服务。...如何解决冲突 若要解决与此规则的冲突,请将返回类型更改为 Uri。 何时禁止显示警告 如果返回不表示 URI,则可以安全地禁止显示此规则发出的警告。...http://www.adventure-works.com") End Function End Class End Namespace 相关规则 CA1056:URI 属性不应是字符串...CA1054:URI 参数不应为字符串 CA2234:传递 System.Uri 对象,而不传递字符串

    48820

    【三十三】springboot+序列化实现返回脱敏和返回字符串时间格式化问题

    一、返回脱敏 1、准备返回对象 ​ 2、准备接口 ​ 3、准备脱敏注解 ​ 4、准备序列化处理类 public class SensitiveInfoSerialize...5、演示原本效果 6、增加注解后效果 二、返回值日期格式化 在开发时返回里的时间一定不只是Date、LocalDateTime、LocalDate,有时候也可能是字符串格式...1、返回增加时间字段 2、原有效果 3、使用常用的@JsonFormat注解进行处理 处理字符串的时间以外,其他的时间都能正常处理,下面通过序列化的方式进行处理该字段...4、增加字符串日期格式处理注解 5、准备序列化处理类 public class StringToDateSerialize extends JsonSerializer

    14210

    【C 语言】字符串模型 ( 字符串翻转模型 | 抽象成业务函数 | 形参返回 | 函数返回 | 函数形参处理 | 形参指针判空 )

    文章目录 一、字符串翻转模型 业务函数 二、完整代码示例 一、字符串翻转模型 业务函数 ---- 将上一篇博客 【C 语言】字符串模型 ( 字符串翻转模型 ) 的代码 , 主要业务逻辑 , 抽象成函数...; 字符串翻转模型 业务函数 要点 : 形参返回 : 函数的返回 , 一般使用 函数形参 间接赋值 进行返回 ; 下面的代码中 char *str 是返回 ; int inverse(char *...str) 函数返回 : 函数的返回 , 反映的是函数的执行结果状态 , 返回 0 执行成功 , 返回 -1 执行失败 ; 函数形参处理 : 在 函数中 , 如果涉及到修改 形参 指针变量 , 一般不直接使用形参...创建临时变量接收 函数形参 , 不要直接改变形参的函数指向 char *str_tmp = str; 形参指针判空 : 函数的第一项任务就是 判定 形参指针是否合法 , 如果任何一个指针为空 , 直接返回...+ len - 1; // 两边向中间遍历 // 利用指向收尾的指针 , 交互指针指向的元素 while (p_start < p_end) { // 交换收尾字符

    92610

    如何给run方法传参?如何处理线程的返回?

    给run()方法传参实现的方式主要有三种 构造函数传参 成员变量传参 回调函数传参 如何实现处理线程的返回 主线程等待法 优点:实现简单 缺点需要自己实现循环逻辑,循环时间自己无法精准控制 使用...FutureTask 的isDone()方法可以用来判断Callable接口实例的call是否执行完毕 3.FutureTask 有个方法是get(),若call()没执行完毕会阻塞住,如果执行完会返回...Callable实例返回 线程池获取 原理和FurureTask差不多,通过线程池submit一个Callable实例会返回一个Future Future也具有FutureTask相同的方法和功能...:``可以提交多个实现callable的类,让线程池并发处理, 方便管理 主线程等待法 join改造上面的主线程只需要替换那个while循环即可 FutureTesk+Callable实现线程返回

    2.7K30

    零学习python 】26. 函数参数与返回的应用

    (一) 一、“返回”介绍 现实生活中的场景: 我给儿子10块钱,让他给我买个冰淇淋。...,只有调用者拥有了这个返回,才能够根据当前的温度做适当的调整 综上所述: 所谓“返回”,就是程序中函数完成一件事情后,最后给调用者的结果 使用返回的前提需求就是函数调用者想要在函数外使用计算结果...二、带有返回的函数 想要在函数中把结果返回给调用者,需要在函数中使用return 如下示例: def add2num(a, b): c = a+b return c # return...,最后儿子给你冰淇淋时,你一定是儿子手中接过来 对么,程序也是如此,如果一个函数返回了一个数据,那么想要用这个数据,那么就需要保存 保存函数的返回示例如下: #定义函数 def add2num(a,...b): return a+b #调用函数,顺便保存函数的返回 result = add2num(100,98) #因为result已经保存了add2num的返回,所以接下来就可以使用了

    14310

    【C 语言】字符串模型 ( 两头堵模型 | 将 两头堵模型 抽象成业务模块函数 | 形参返回 | 函数返回 | 形参指针判空 | 形参返回操作 )

    文章目录 一、将 两头堵模型 抽象成业务模块函数 二、完整代码示例 一、将 两头堵模型 抽象成业务模块函数 ---- 将 两头堵模型 抽象成业务模块函数 相关要点 : 形参返回 : 函数的返回 ,...一般使用 函数形参 间接赋值 进行返回 ; 下面的代码中 int *count 是返回 ; int get_count(char *str_all, int *count) 函数返回 : 函数的返回...== NULL || count == NULL"); return -1; } 形参返回操作 : 函数的真正返回 , 不要急着写入到指针指向的内存中 , 先放在局部变量中...= 0; // 循环条件是 i 指针指向的 位置 为空 则继续循环 // 遇到第一个不为空的字符 , 便停止循环 // 停止循环时的 i 指向左侧开始第一个不为空的字符...{ i++; } // 循环条件是 j 指针指向的 位置 为空 则继续循环 // 遇到第一个不为空的字符 , 便停止循环 // 停止循环时的 j 指向右侧开始第一个不为空的字符

    71420
    领券