我在做一个Csv文件的自动解析工具,实现效果根据文件路径、目标Class对象和对应属性名数组返回一个封装好的List,方法类似于 List<T> parseFile(String path, Class c, String[] fields)。
    现在的问题是解析出来的属性值全部是String类型的,而有些属性本身是int或double类型,我没办法根据合适的方法强制转换成合适的类型,所以会报错,代码....
Object o = c.newInstance();
String str = cellValue;//取到的值
Field f = c.getDeclaredField(fields[i]);
f.setAccessiable(true);
f.set(o, str);//这个时候属性的类型不一定是String的
f.setAccessiable(false);
....不知道有没有好的方法可以指教一下?

解决方案 »

  1.   


    public static void getObjectValue(Object object) throws Exception {
    //我们项目的所有实体类都继承BaseDomain (所有实体基类:该类只是串行化一下)
    //不需要的自己去掉即可
    if (object != null && object instanceof BaseDomain) {//if (object!=null )  ----begin
    // 拿到该类
    Class<?> clz = object.getClass();
    // 获取实体类的所有属性,返回Field数组
    Field[] fields = clz.getDeclaredFields(); for (Field field : fields) {// --for() begin
    System.out.println(field.getGenericType());//打印该类的所有属性类型 // 如果类型是String
    if (field.getGenericType().toString().equals(
    "class java.lang.String")) { // 如果type是类类型,则前面包含"class ",后面跟类名
    // 拿到该属性的gettet方法
    /**
     * 这里需要说明一下:他是根据拼凑的字符来找你写的getter方法的
     * 在Boolean值的时候是isXXX(默认使用ide生成getter的都是isXXX)
     * 如果出现NoSuchMethod异常 就说明它找不到那个gettet方法 需要做个规范
     */
    Method m = (Method) object.getClass().getMethod(
    "get" + getMethodName(field.getName())); String val = (String) m.invoke(object);// 调用getter方法获取属性值
    if (val != null) {
    System.out.println("String type:" + val);
    } } // 如果类型是Integer
    if (field.getGenericType().toString().equals(
    "class java.lang.Integer")) {
    Method m = (Method) object.getClass().getMethod(
    "get" + getMethodName(field.getName()));
    Integer val = (Integer) m.invoke(object);
    if (val != null) {
    System.out.println("Integer type:" + val);
    } } // 如果类型是Double
    if (field.getGenericType().toString().equals(
    "class java.lang.Double")) {
    Method m = (Method) object.getClass().getMethod(
    "get" + getMethodName(field.getName()));
    Double val = (Double) m.invoke(object);
    if (val != null) {
    System.out.println("Double type:" + val);
    } } // 如果类型是Boolean 是封装类
    if (field.getGenericType().toString().equals(
    "class java.lang.Boolean")) {
    Method m = (Method) object.getClass().getMethod(
    field.getName());
    Boolean val = (Boolean) m.invoke(object);
    if (val != null) {
    System.out.println("Boolean type:" + val);
    } } // 如果类型是boolean 基本数据类型不一样 这里有点说名如果定义名是 isXXX的 那就全都是isXXX的
    // 反射找不到getter的具体名
    if (field.getGenericType().toString().equals("boolean")) {
    Method m = (Method) object.getClass().getMethod(
    field.getName());
    Boolean val = (Boolean) m.invoke(object);
    if (val != null) {
    System.out.println("boolean type:" + val);
    } }
    // 如果类型是Date
    if (field.getGenericType().toString().equals(
    "class java.util.Date")) {
    Method m = (Method) object.getClass().getMethod(
    "get" + getMethodName(field.getName()));
    Date val = (Date) m.invoke(object);
    if (val != null) {
    System.out.println("Date type:" + val);
    } }
    // 如果类型是Short
    if (field.getGenericType().toString().equals(
    "class java.lang.Short")) {
    Method m = (Method) object.getClass().getMethod(
    "get" + getMethodName(field.getName()));
    Short val = (Short) m.invoke(object);
    if (val != null) {
    System.out.println("Short type:" + val);
    } }
    // 如果还需要其他的类型请自己做扩展 }//for() --end

    }//if (object!=null )  ----end
    } // 把一个字符串的第一个字母大写、效率是最高的、
    private static String getMethodName(String fildeName) throws Exception{
    byte[] items = fildeName.getBytes();
    items[0] = (byte) ((char) items[0] - 'a' + 'A');
    return new String(items);
    }