原文:把数据库中有关枚举项值的数字字符串转换成文字字符串

标题可能无法表达我的本意。比如,有这样一个枚举:

    public enum MyChoice
    {
        MyFirstChoice = 0,
        MySecondChoice =1,
        MyThirdChoice = 2
    }

数据库中,某表某字段保存值为"0,1,2",在显示的时候,我们希望是"第一个选择,第二个选择,第三个选择"。如何做呢?

可以为枚举项上面标注自定义特性。先自定义一个特性如下:

    public class EnumDisplayNameAttribute : Attribute
    {
        private string _displayName;
        public EnumDisplayNameAttribute(string displayName)
        {
            _displayName = displayName;
        }
        public string DisplayName
        {
            get
            {
                return _displayName;
            }
        }
    }

然后,把自定义特性标注放到枚举项上去。

    public enum MyChoice
    {
        [EnumDisplayName("我的第一个选择")]
        MyFirstChoice = 0,
        [EnumDisplayName("我的第二个选择")]
        MySecondChoice =1,
        [EnumDisplayName("我的第三个选择")]
        MyThirdChoice = 2
    }

现在,需要一个帮助方法,能读出枚举项上的自定义特性EnumDisplayName。

   public class EnumExt
    {
        /// <summary>
        /// 获取枚举项的注释
        /// </summary>
        /// <param name="e">枚举项</param>
        /// <returns></returns>
        public static string GetEnumDescription(object e)
        {
            //获取枚举项
            Type t = e.GetType();
            //获取枚举项的字段
            FieldInfo[] fis = t.GetFields();
            foreach (FieldInfo fi in fis)
            {
                //如果当前字段名称不是当前枚举项
                if (fi.Name != e.ToString())
                {
                    continue;//结束本次循环
                }
                //如果当前字段的包含自定义特性
                if (fi.IsDefined(typeof (EnumDisplayNameAttribute), true))
                {
                    //获取自定义特性的属性值
                    return (fi.GetCustomAttributes(typeof(EnumDisplayNameAttribute), true)[0] as EnumDisplayNameAttribute).DisplayName;
                }
            }
            return e.ToString();
        }
        public static List<SelectListItem> GetSelectList(Type enumType)
        {
            List<SelectListItem> selectList = new List<SelectListItem>();
            //selectList.Add(new SelectListItem{Text = "--请选择--",Value = ""});
            foreach (object e in Enum.GetValues(enumType))
            {
                selectList.Add(new SelectListItem { Text = GetEnumDescription(e), Value = ((int)e).ToString() });
            }
            return selectList;
        }
    }

以上,

● GetEnumDescription方法根据枚举项获取其上的自定义特性EnumDisplayNameAttribute的DisplayName属性值。

● GetSelectList方法根据枚举的Type类型返回SelectListItem集合,通常在ASP.NET MVC中使用。

最后,就能实现本篇的需求:

        static void Main(string[] args)
        {
            string myChoiceInt = "0,1,2";
            string[] choiceArr = myChoiceInt.Split(',');
            string temp = string.Empty;
            foreach (string item in choiceArr)
            {
                //转换成枚举的类型
                short enumValShort = short.Parse(item);
                temp = temp + EnumExt.GetEnumDescription((MyChoice)enumValShort) + ",";
            }
            Console.WriteLine(temp.Substring(0, temp.Length - 1));
            Console.ReadKey();
        }

把数据库中有关枚举项值的数字字符串转换成文字字符串相关推荐

  1. MySQL 数据库中如何将表字段的空值全部替换成空字符串

    UPDATE permissions SET name = ( CASE WHEN IFNULL(name, '') = '' THEN '' ELSE name END ) WHERE name I ...

  2. json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值...

    json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值 原文:json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值 主要内容: 一 ...

  3. 微信录音滑动撤销 html5,微信中这个被取消的功能悄悄上线了,将语音上滑即可转换成文字...

    原标题:微信中这个被取消的功能悄悄上线了,将语音上滑即可转换成文字 微信中有一个之前被取消的功能又悄悄上线了,你发现了吗?那么问题来了,是什么功能呢?就是之前在测试版中出现过的语音转文字功能啦~正式版 ...

  4. swift_031(Swift 中的枚举/原始值(RawValues))

    枚举定义语法 首先,我们来看看在 swift 中定义枚举的语法: enum WeekDay {case Mondaycase Tuesdaycase Wednesdaycase Thursdaycas ...

  5. 【原创】数据库中时间字段的值读取到DataSet中后,毫秒部分丢失。

    数据库中时间字段的值读取到DataSet中后,毫秒部分丢失. 在网上查了些解决方案,说读取时间时,先转化为DateTime类型,然后在ToString("yyyy-MM-dd HH:mm:s ...

  6. 【报错笔记】在做图片上传时上传图片后可以跳转到上传成功界面,也没有报错,数据库中也传入了值,可是eclipse中webapp下怎样都无法生存目录。

    在做图片上传时上传图片后可以跳转到上传成功界面,也没有报错,数据库中也传入了值,可是eclipse中webapp下怎样都无法生存目录. 我使用UUID生成8级目录,在webapp下创建目录,将图片传进 ...

  7. 24.shell中list详解,定义list,获取List的总个数,获取list的某个元素值,将list的每个元素转换成以空格分隔的字符串,空格分隔的字符串转换成list,for循环list

    文章目录 前言 定义list 获取List的总个数 获取list的某个元素值 将list的每个元素转换成以空格分隔的字符串 空格分隔的字符串转换成list for循环list 总结 友情链接 前言 s ...

  8. 将JAVA bean/实体类 中为null的属性值转换成空字符串

    使bean中为null的属性转换成空字符串 获得getter方法 方法有分带参数和不带参数,我们知道getter方法是不带参数的 获得getter方法如下 Method m = model.getCl ...

  9. php将sql语句识别成字符串,ASP_把字符串转换成数据库SQL语句格式,复制代码 代码如下:'把字符串 - phpStudy...

    把字符串转换成数据库SQL语句格式 复制代码 代码如下: '把字符串转换成数据库SQL语句格式 '------------------------------------------------- F ...

最新文章

  1. springboot +element-axios跨域请求
  2. mysql简易oa系统_基于mybatis设计简单OA系统问题2
  3. java 子类重写父类的方法的注意事项
  4. 项目进度,你汇报清楚了么?
  5. JAVA变量的数据类型样例
  6. mybatis逆向工程生成的实体类和表不一致缺少某些字段或者出现其他字段
  7. bootstrap项目更改为vue_取代Jquery,用Vue 构建Bootstrap 4 应用
  8. centOS7 安装redis-3.2.6
  9. java ajax html复选框,HTMLjavaSkcriptCSSjQueryajax(九)(示例代码)
  10. C语言实现hello world代码
  11. PICT的安装及使用
  12. lua脚本的加密和解密(GG游戏脚本)
  13. c语言 自动答题器,单片机原理作业—电子答题器(课程及设计).doc
  14. 计算机基础算术加法,计算机基础第二章:算术逻辑单元(How Computes Calculate——The ALU)...
  15. Contexts for mac(程序快速调用工具)
  16. 【日语】英语26个字母的日语读法
  17. unity添加android res资源,Unity3d常用两种加载资源方案:Resources.Load和AssetBundle
  18. 在Unity中使用ComputeShader
  19. 项目:金融行业反欺诈模型
  20. 三菱FX系列PLC以太网通讯

热门文章

  1. Gitlab CI(一)
  2. 特征点匹配+特征检测方法汇总
  3. javascript解析json
  4. 由浅入深剖析.htaccess
  5. C#实现Des加密和解密
  6. C#下用P2P技术实现点对点聊天
  7. 用Response.Write和Page.RegisterStartupScript显示的提示框有什么区别
  8. Linux下__attribute__((visibility (default)))的使用
  9. TensorRT Samples: CharRNN
  10. 整理《Mastering OpenCV with Practical Computer Vision Projects》中第8章用Eigenfaces或Fisherfaces进行人脸识别操作流程