zoukankan      html  css  js  c++  java
  • c# 利用反射设置属性值

            /// <summary>
              /// 设置相应属性的值
              /// </summary>
              /// <param name="entity">实体</param>
              /// <param name="fieldName">属性名</param>
              /// <param name="fieldValue">属性值</param>
              public static void SetValue(object entity, string fieldName, string fieldValue)
              {
                  Type entityType = entity.GetType();
     
                 PropertyInfo propertyInfo = entityType.GetProperty(fieldName);
     
                 if (IsType(propertyInfo.PropertyType, "System.String"))
                 {
                     propertyInfo.SetValue(entity, fieldValue, null);
     
                 }
     
                 if (IsType(propertyInfo.PropertyType, "System.Boolean"))
                 {
                     propertyInfo.SetValue(entity, Boolean.Parse(fieldValue), null);
     
                 }
     
                 if (IsType(propertyInfo.PropertyType, "System.Int32"))
                 {
                     if (fieldValue != "")
                         propertyInfo.SetValue(entity, int.Parse(fieldValue), null);
                     else
                         propertyInfo.SetValue(entity, 0, null);
     
                }
     
                 if (IsType(propertyInfo.PropertyType, "System.Decimal"))
                 {
                     if (fieldValue != "")
                         propertyInfo.SetValue(entity, Decimal.Parse(fieldValue), null);
                     else
                         propertyInfo.SetValue(entity, new Decimal(0), null);
     
                 }
     
                 if (IsType(propertyInfo.PropertyType, "System.Nullable`1[System.DateTime]"))
                 {
                     if (fieldValue != "")
                     {
                        try
                         {
                             propertyInfo.SetValue(
                                 entity,
                                 (DateTime?)DateTime.ParseExact(fieldValue, "yyyy-MM-dd HH:mm:ss", null), null);
                         }
                         catch
                         {
                             propertyInfo.SetValue(entity, (DateTime?)DateTime.ParseExact(fieldValue, "yyyy-MM-dd", null), null);
                         }
                     }
                     else
                         propertyInfo.SetValue(entity, null, null);
     
                 }
     
             }
             /// <summary>
             /// 类型匹配
             /// </summary>
             /// <param name="type"></param>
             /// <param name="typeName"></param>
             /// <returns></returns>
             public static bool IsType(Type type, string typeName)
             {
                 if (type.ToString() == typeName)
                     return true;
                 if (type.ToString() == "System.Object")
                     return false;
     
                 return IsType(type.BaseType, typeName);
             }
  • 相关阅读:
    SQL 通配符
    SQL 中定义别名
    SQL 语句执行顺序
    将汉字散列存储
    FileStream写文本文档时候显示其他进程正在访问的问题
    向数据库中添加含有单引号的数据
    整词二分、逐字二分的分词词典机制
    C# 集合类总结(Array,Arraylist,List,Hashtable,Dictionary,Stack,Queue)
    固定表格宽度
    对于交叉表的实现及多重表头的应用
  • 原文地址:https://www.cnblogs.com/yeagen/p/2662494.html
Copyright © 2011-2022 走看看