把数据库中有关枚举项值的数字字符串转换成文字字符串
标题可能无法表达我的本意。比如,有这样一个枚举:
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();
}
把数据库中有关枚举项值的数字字符串转换成文字字符串相关推荐
- MySQL 数据库中如何将表字段的空值全部替换成空字符串
UPDATE permissions SET name = ( CASE WHEN IFNULL(name, '') = '' THEN '' ELSE name END ) WHERE name I ...
- json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值...
json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值 原文:json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值 主要内容: 一 ...
- 微信录音滑动撤销 html5,微信中这个被取消的功能悄悄上线了,将语音上滑即可转换成文字...
原标题:微信中这个被取消的功能悄悄上线了,将语音上滑即可转换成文字 微信中有一个之前被取消的功能又悄悄上线了,你发现了吗?那么问题来了,是什么功能呢?就是之前在测试版中出现过的语音转文字功能啦~正式版 ...
- swift_031(Swift 中的枚举/原始值(RawValues))
枚举定义语法 首先,我们来看看在 swift 中定义枚举的语法: enum WeekDay {case Mondaycase Tuesdaycase Wednesdaycase Thursdaycas ...
- 【原创】数据库中时间字段的值读取到DataSet中后,毫秒部分丢失。
数据库中时间字段的值读取到DataSet中后,毫秒部分丢失. 在网上查了些解决方案,说读取时间时,先转化为DateTime类型,然后在ToString("yyyy-MM-dd HH:mm:s ...
- 【报错笔记】在做图片上传时上传图片后可以跳转到上传成功界面,也没有报错,数据库中也传入了值,可是eclipse中webapp下怎样都无法生存目录。
在做图片上传时上传图片后可以跳转到上传成功界面,也没有报错,数据库中也传入了值,可是eclipse中webapp下怎样都无法生存目录. 我使用UUID生成8级目录,在webapp下创建目录,将图片传进 ...
- 24.shell中list详解,定义list,获取List的总个数,获取list的某个元素值,将list的每个元素转换成以空格分隔的字符串,空格分隔的字符串转换成list,for循环list
文章目录 前言 定义list 获取List的总个数 获取list的某个元素值 将list的每个元素转换成以空格分隔的字符串 空格分隔的字符串转换成list for循环list 总结 友情链接 前言 s ...
- 将JAVA bean/实体类 中为null的属性值转换成空字符串
使bean中为null的属性转换成空字符串 获得getter方法 方法有分带参数和不带参数,我们知道getter方法是不带参数的 获得getter方法如下 Method m = model.getCl ...
- php将sql语句识别成字符串,ASP_把字符串转换成数据库SQL语句格式,复制代码 代码如下:'把字符串 - phpStudy...
把字符串转换成数据库SQL语句格式 复制代码 代码如下: '把字符串转换成数据库SQL语句格式 '------------------------------------------------- F ...
最新文章
- springboot +element-axios跨域请求
- mysql简易oa系统_基于mybatis设计简单OA系统问题2
- java 子类重写父类的方法的注意事项
- 项目进度,你汇报清楚了么?
- JAVA变量的数据类型样例
- mybatis逆向工程生成的实体类和表不一致缺少某些字段或者出现其他字段
- bootstrap项目更改为vue_取代Jquery,用Vue 构建Bootstrap 4 应用
- centOS7 安装redis-3.2.6
- java ajax html复选框,HTMLjavaSkcriptCSSjQueryajax(九)(示例代码)
- C语言实现hello world代码
- PICT的安装及使用
- lua脚本的加密和解密(GG游戏脚本)
- c语言 自动答题器,单片机原理作业—电子答题器(课程及设计).doc
- 计算机基础算术加法,计算机基础第二章:算术逻辑单元(How Computes Calculate——The ALU)...
- Contexts for mac(程序快速调用工具)
- 【日语】英语26个字母的日语读法
- unity添加android res资源,Unity3d常用两种加载资源方案:Resources.Load和AssetBundle
- 在Unity中使用ComputeShader
- 项目:金融行业反欺诈模型
- 三菱FX系列PLC以太网通讯
热门文章
- Gitlab CI(一)
- 特征点匹配+特征检测方法汇总
- javascript解析json
- 由浅入深剖析.htaccess
- C#实现Des加密和解密
- C#下用P2P技术实现点对点聊天
- 用Response.Write和Page.RegisterStartupScript显示的提示框有什么区别
- Linux下__attribute__((visibility (default)))的使用
- TensorRT Samples: CharRNN
- 整理《Mastering OpenCV with Practical Computer Vision Projects》中第8章用Eigenfaces或Fisherfaces进行人脸识别操作流程