GVKun编程网logo

利用反射过滤对象的null值(通过反射获取对象的属性值)

15

在本文中,我们将带你了解利用反射过滤对象的null值在这篇文章中,我们将为您详细介绍利用反射过滤对象的null值的方方面面,并解答通过反射获取对象的属性值常见的疑惑,同时我们还将给您一些技巧,以帮助您

在本文中,我们将带你了解利用反射过滤对象的null值在这篇文章中,我们将为您详细介绍利用反射过滤对象的null值的方方面面,并解答通过反射获取对象的属性值常见的疑惑,同时我们还将给您一些技巧,以帮助您实现更有效的c# – 如何将Nullable DateTime变量的null值转换为DbNull.Value、C#利用反射根据类名创建类的实例对象的详细介绍、fastjson 处理null值,对象为null时返回{},数字为null返回[]、hive null值的过滤

本文目录一览:

利用反射过滤对象的null值(通过反射获取对象的属性值)

利用反射过滤对象的null值(通过反射获取对象的属性值)

项目的数据库在 测试插入的时候 添加了很多空的数据进去 不是null 而是直接的varvhar格式的 字符串 "NULL" 这放在页面上会让人误解是bug 所以 写了一个方法_ 过滤 这些 NULL 的字符串_ 不让他显示在前台页面 写在这里也仅仅为了 以后要用的时候能 copy 23333-------------------------

//用了泛型 可以是任意的对象传入
public static <T> void nullFilter(T t){
		 // 获取实体类的所有属性,返回Field数组
		Field[] field = t.getClass().getDeclaredFields();
        try {
            for (int j = 0; j < field.length; j++) { // 遍历所有属性
                String name = field[j].getName(); // 获取属性的名字
                name = name.substring(0, 1).toUpperCase() + name.substring(1); // 将属性的首字符大写,方便构造get,set方法
                String type = field[j].getGenericType().toString(); // 获取属性的类型
            	// 只找String类型的 属性进行过滤
                if (type.equals("class java.lang.String")) { 
                	//让这个属性可以被共有访问
                	field[j].setAccessible(true);
                	Object obj = field[j].get(t);
                	if(obj!=null){
	                    Method m = t.getClass().getMethod("get" + name);
	                    // 调用getter方法获取属性值
	                    String value = (String) m.invoke(t); 
	                    //只要是null的字符串 先全转成大写 匹配大写 并且给他空串还是null
	                    if ("NULL".equals(value.toUpperCase())) {
	                        m = t.getClass().getMethod("set"+name,String.class);
	                        m.invoke(t, "");
	                    }
                	}
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        } 
	}

c# – 如何将Nullable DateTime变量的null值转换为DbNull.Value

c# – 如何将Nullable DateTime变量的null值转换为DbNull.Value

我有一个可以为空的DateTime变量.我想把它写到sql DB.当我尝试插入时:

如果变量有值,则没有问题.

但如果它没有值,则插入中断错误.

我想问:我们如何通过DbCommand参数将可空的DateTime插入sql?

(P.S.:sql列也可以为空.)

DateTime? myDate = null;
DbCommand dbCommand = new DbCommand();
dbCommand.Parameters.Add("NullablesqlDateField",DbType.DateTime,myDate);

解决方法

试试 null coalescing operator:

dbCommand.Parameters.Add("NullablesqlDateField",(object) myDate ?? dbnull.Value);

C#利用反射根据类名创建类的实例对象的详细介绍

C#利用反射根据类名创建类的实例对象的详细介绍

这篇文章主要介绍了详解c# 利用反射根据类名创建类的实例对象,“反射”其实就是利用程序集的元数据信息,感兴趣的小伙伴们可以参考一下。

“反射”其实就是利用程序集的元数据信息。 反射可以有很多方法,编写程序时请先导入 System.Reflection 命名空间。

1、假设你要反射一个 DLL 中的类,并且没有引用它(即未知的类型):


Assembly assembly = Assembly.LoadFile("程序集路径,不能是相对路径"); // 加载程序集(EXE 或 DLL) 
dynamic obj = assembly.CreateInstance("类的完全限定名(即包括命名空间)"); // 创建类的实例
登录后复制

2、若要反射当前项目中的类(即当前项目已经引用它了)可以为:


Assembly assembly = Assembly.GetExecutingAssembly(); // 获取当前程序集 
dynamic obj = assembly.CreateInstance("类的完全限定名(即包括命名空间)"); 
// 创建类的实例,返回为 object 类型,需要强制类型转换
登录后复制

3、也可以为:


Type type = Type.GetType("类的完全限定名"); 
dynamic obj = type.Assembly.CreateInstance(type);
登录后复制

4、不同程序集的话,则要装载调用,代码如下:

System.Reflection.Assembly.Load("程序集名称(不含文件后缀名)").CreateInstance("命名空间.类名", false);

如:

代码如下:

dynamic o = System.Reflection.Assembly.Load("MyDll").CreateInstance("MyNameSpace.A", false);
登录后复制

注意:由于要用到dynamic ,需要把target 改为4.0 ,如果编译时出现“找不到编译动态表达式所需的一个或多个类型。是否缺少引用?”的错误,是因为缺少一个引用,在项目里引用Miscorsoft.CSharp类库,添加后就能编译成功。

=======================================================

补充:

1)反射创建某个类的实例时,必须保证使用类的完全限定名(命名空间 + 类名)。Type.GetType 方法返回 null 则意味搜索元数据中的相关信息失败(反射失败),请确保反射时使用类的完全限定名。

2)反射功能十分强大,没有什么不能实现的。若实现“跨程序集”,请使用第一种方法创建类的实例,并反射该实例的字段、属性、方法、事件... 然后动态调用之。


  /// <summary>
  /// 反射帮助类
  /// </summary>
  public static class ReflectionHelper
  {
    /// <summary>
    /// 创建对象实例
    /// </summary>
    /// <typeparam name="T"></typeparam>
    /// <param name="fullName">命名空间.类型名</param>
    /// <param name="assemblyName">程序集</param>
    /// <returns></returns>
    public static T CreateInstance<T>(string fullName, string assemblyName)
    {
      string path = fullName + "," + assemblyName;//命名空间.类型名,程序集
      Type o = Type.GetType(path);//加载类型
      object obj = Activator.CreateInstance(o, true);//根据类型创建实例
      return (T)obj;//类型转换并返回
    }

    /// <summary>
    /// 创建对象实例
    /// </summary>
    /// <typeparam name="T">要创建对象的类型</typeparam>
    /// <param name="assemblyName">类型所在程序集名称</param>
    /// <param name="nameSpace">类型所在命名空间</param>
    /// <param name="className">类型名</param>
    /// <returns></returns>
    public static T CreateInstance<T>(string assemblyName, string nameSpace, string className)
    {
      try
      {
        string fullName = nameSpace + "." + className;//命名空间.类型名
        //此为第一种写法
        object ect = Assembly.Load(assemblyName).CreateInstance(fullName);//加载程序集,创建程序集里面的 命名空间.类型名 实例
        return (T)ect;//类型转换并返回
        //下面是第二种写法
        //string path = fullName + "," + assemblyName;//命名空间.类型名,程序集
        //Type o = Type.GetType(path);//加载类型
        //object obj = Activator.CreateInstance(o, true);//根据类型创建实例
        //return (T)obj;//类型转换并返回
      }
      catch
      {
        //发生异常,返回类型的默认值
        return default(T);
      }
    }
  }
登录后复制

以上就是C#利用反射根据类名创建类的实例对象的详细介绍的详细内容,更多请关注php中文网其它相关文章!

fastjson 处理null值,对象为null时返回{},数字为null返回[]

fastjson 处理null值,对象为null时返回{},数字为null返回[]

针对这一情况。

我用的json转换工具是fastjson,网上查知fastjson 有ValueFilter接口可以实现自定义过滤

packagecom.alibaba.fastjson.serializer;

publicinterfaceValueFilterextendsSerializefilter{

Objectprocess(Objectobject,Stringname,Objectvalue);
}

知道接口后就简单了。

process(Objectobject,Objectvalue)//三个参数,object为要转成json的对象,name是对象的get/is方法的名字(去掉get或is前缀并首字母小写),value就是对应的get值

//思路就是通过object和name反射方法得出其return的类型。针对value==null的基础数据类型的或者list的类型的做出不同处理
//实现的部分代码(PS:时间类型我也算到基础类型了。)
	privatestaticString[]types={"java.lang.Integer","java.lang.Double","java.lang.Float","java.lang.Long","java.lang.Short","java.lang.Byte","java.lang.Boolean","java.lang.Char","java.lang.String","java.util.Date","int","double","long","short","byte","boolean","char","float"};
	
	
	privatestaticStringfirst2Up(Stringstr){
		returnstr.substring(0,1).toupperCase()+str.substring(1);
	}
	
	privatestaticValueFilternullValueFilter=newValueFilter(){
		@Override
		publicObjectprocess(Objectobject,Objectvalue){
			if(value==null){
			try{
				Methodmethod=object.getClass().getDeclaredMethod("get"+first2Up(name));
				
				for(Stringtype:types){
					if(method.getReturnType().getName().equals(type)){
							return"";
						}
				}
				
				if(method.getReturnType().isAssignableFrom(List.class)&&
						!method.getReturnType().getName().equals("java.lang.Object")){
					returnnewint[0];
					}
				
				returnnewObject();
					
				}catch(SecurityException|NoSuchMethodExceptione){
					e.printstacktrace();
					returnvalue;
				}
		}
		returnvalue;
		}
		
	};

	privatestaticStringdateFormat="yyyy-MM-ddHH:mm:ss";
	privatestaticSerializeConfigmapping=newSerializeConfig();
	static{
		mapping.put(Date.class,newSimpleDateFormatSerializer(dateFormat));
	}
//只是部分代码,有些数字类型,也需要加上引号过滤的对象是notNullValueFilter,原理一样,就不贴出来了,mapping是对日期的格式化方法
	publicstaticStringtoJsonString(Objectobj){
		Serializefilter[]filters={nullValueFilter,notNullValueFilter};
		returnjsON.toJSONString(obj,mapping,filters);
	}


附上原先的json接口转换方法,希望能抛砖引玉

publicStringobject2Json(Objectobject)throwsIOException{
		if(!objectUtil.isNotEmpty(object)){
			return"";
		}
		ObjectMappermapper=JacksonMapper.getInstance();
		
		//字段和值都加引号
		mapper.configure(JsonParser.Feature.ALLOW_UNQUOTED_FIELD_NAMES,true);

		//数字加引号
		mapper.configure(JsonGenerator.Feature.WRITE_NUMBERS_AS_STRINGS,true);
		mapper.configure(JsonGenerator.Feature.QUOTE_NON_NUMERIC_NUMBERS,true);
	
		
		mapper.getSerializerProvider().setNullValueSerializer(newJsonSerializer<Object>()
{
publicvoidserialize(
Objectvalue,JsonGeneratorjg,SerializerProvidersp)throwsIOException,JsonProcessingException
{
jg.writeString("");
}
});
		returnmapper.writeValueAsstring(object);
	}

hive null值的过滤

hive null值的过滤

请教各位一个问题,hive中表A,通过SET SERDEPROPERTIES(''serialization.null.format'' = '''')将null的底层存储改为空,表中有字段id,类型为string,那么

(1)表中有一条记录r1,其id为null,执行select时,使用where id <> ''0'',记录r1是否能出现在select结果中;

(2)表中有另一记录r2,其id为cast(null as string),执行select时,使用where id <> ''0'', 记录r2是否会出现在select结果中

求助大神帮忙解答!!

今天关于利用反射过滤对象的null值通过反射获取对象的属性值的分享就到这里,希望大家有所收获,若想了解更多关于c# – 如何将Nullable DateTime变量的null值转换为DbNull.Value、C#利用反射根据类名创建类的实例对象的详细介绍、fastjson 处理null值,对象为null时返回{},数字为null返回[]、hive null值的过滤等相关知识,可以在本站进行查询。

本文标签: