object对象转换成map_object强转成map

object对象转换成map_object强转成map1、Object转换成map的方法importjava.lang.reflect.Field;importjava.util.HashMap;importjava.util.Map;/***将Object对象里面的属性和值转化成Map对象**@paramobj*@return*@throwsIllegalAccessException*/publicstaticMap<String,

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

1、Object转换成map的方法

import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.Map;


/**
     * 将Object对象里面的属性和值转化成Map对象
     *
     * @param obj
     * @return
     * @throws IllegalAccessException
     */
    public static Map<String, Object> objectToMap(Object obj) throws IllegalAccessException {
        Map<String, Object> map = new HashMap<String,Object>();
        Class<?> clazz = obj.getClass();
        for (Field field : clazz.getDeclaredFields()) {
            field.setAccessible(true);
            String fieldName = field.getName();
            Object value = field.get(obj);
            map.put(fieldName, value);
        }
        return map;
    }

Jetbrains全家桶1年46,售后保障稳定

2、转换前的数据格式

SearchHit{id='awQWpXgBwGXBeoctg1F5', score=2.1747518, sortValues=[], content=User(id=awQWpXgBwGXBeoctg1F5, name=吴京, msg=我是演员, job=演员, sex=男, age=12, createDate=Tue Apr 06 08:00:00 CST 2021), highlightFields={}}

3、转换后的数据

{score=2.1747518, innerHits={}, highlightFields={}, index=user, id=awQWpXgBwGXBeoctg1F5, nestedMetaData=null, sortValues=[], content=User(id=awQWpXgBwGXBeoctg1F5, name=吴京, msg=我是演员, job=演员, sex=男, age=12, createDate=Tue Apr 06 08:00:00 CST 2021)}

4、取map中的值

map.get("content")

5、map转实体对象

List searchHits = user.getSearchHits();

List<User> users = new ArrayList<>();
        for (Object o : searchHits) {
            Map<String, Object> map = new HashMap<>();
            map = objectToMap(o);
            Map<String, Object> userMap = objectToMap(map.get("content"));
            User user1 = mapToBean(userMap);
            System.out.println("哈哈哈哈哈转换成功:"+user1.getMsg());
            users.add(user1);
        }

6、map转实体类对象利用的方法

参数类型按实际的实体类进行增加

/**
     * map 转 实体类
     *
     * @param map
     * @return
     * @throws Exception
     */
    public User mapToBean(Map<String, Object> map)
            throws Exception {
        User permission = new User();
        if (map != null) {
            Field[] declaredFields = User.class.getDeclaredFields();
            if (declaredFields != null) {

                for (Field declaredField : declaredFields) {
                    declaredField.setAccessible(true);
                    Set<String> mapKeys = map.keySet();

                    for (String mapKey : mapKeys) {

                        if (declaredField.getType().toString().contains("Integer"))//判断属性类型 进行转换,map中存放的是Object对象需要转换 实体类中有多少类型就加多少类型,实体类属性用包装类;
                            if (declaredField.getName().equals(mapKey)) {
                                declaredField.set(permission, Integer.valueOf(map.get(mapKey).toString()));
                                break;
                            }
                        if (declaredField.getType().toString().contains("String"))//判断属性类型 进行转换;
                            if (declaredField.getName().equals(mapKey)) {
                                declaredField.set(permission, map.get(mapKey));

                                break;
                            }
                        if (declaredField.getType().toString().contains("Float"))//判断属性类型 进行转换;
                            if (declaredField.getName().equals(mapKey)) {
                                declaredField.set(permission, Float.valueOf(map.get(mapKey).toString()));

                                break;
                            }

                        if (declaredField.getType().toString().contains("Long"))//判断属性类型 进行转换;
                            if (declaredField.getName().equals(mapKey)) {
                                declaredField.set(permission, Long.valueOf(map.get(mapKey).toString()));
                                break;
                            }

                        if (declaredField.getType().toString().contains("Date"))//判断属性类型 进行转换;
                            if (declaredField.getName().equals(mapKey)) {
                                String s = map.get(mapKey).toString();
                                Date parse = parse(s, "EEE MMM dd HH:mm:ss zzz yyyy", Locale.US);
                                declaredField.set(permission, parse);
                                break;
                            }

                    }
                }
            }

        }

        return permission;

7、里面用到的时间格式是格林威治,实体类存的是Date,具体方法如下:

// 格林威治时间转Date
    private Date parse(String str, String pattern, Locale locale) {
        if (str == null || pattern == null) {
            return null;
        }
        try {
            return new SimpleDateFormat(pattern, locale).parse(str);
        } catch (ParseException e) {
            e.printStackTrace();
        }
        return null;
    }

8、完整代码在下面,因为我用的是springboot+es,所以,根据具体情况灵活变动

package com.springboot.demo.es;

import com.springboot.demo.entity.User;
import com.springboot.demo.mapper.UserResipotry;
import org.apache.tomcat.util.buf.StringUtils;
import org.elasticsearch.index.query.BoolQueryBuilder;
import org.elasticsearch.index.query.QueryBuilders;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.elasticsearch.core.ElasticsearchRestTemplate;
import org.springframework.data.elasticsearch.core.SearchHits;
import org.springframework.data.elasticsearch.core.mapping.IndexCoordinates;
import org.springframework.data.elasticsearch.core.query.GetQuery;
import org.springframework.data.elasticsearch.core.query.NativeSearchQueryBuilder;

import javax.xml.crypto.Data;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.Map;

/**
 * @author dt
 * @date 2021年04月06日10:47
 */
@SpringBootTest
public class EsDemo01 {


    @Autowired
    private ElasticsearchRestTemplate elasticsearchRestTemplate;

   
    @Test
    void test4() throws Exception {

        //组合条件对象
        BoolQueryBuilder boolQuery = QueryBuilders.boolQuery();
        boolQuery.must(QueryBuilders.matchQuery("name", "吴京"));

        NativeSearchQueryBuilder nativeSearchQueryBuilder = new NativeSearchQueryBuilder();
        nativeSearchQueryBuilder.withQuery(boolQuery);
        SearchHits user = elasticsearchRestTemplate.search(nativeSearchQueryBuilder.build(), User.class, IndexCoordinates.of("user"));
        List searchHits = user.getSearchHits();

        List<User> users = new ArrayList<>();
        for (Object o : searchHits) {
            Map<String, Object> map = new HashMap<>();
            map = objectToMap(o);
            Map<String, Object> userMap = objectToMap(map.get("content"));
            User user1 = mapToBean(userMap);
            System.out.println("哈哈哈哈哈转换成功:"+user1.getMsg());
            users.add(user1);
        }

        System.out.println(users);

    }


    /**
     * 将Object对象里面的属性和值转化成Map对象
     *
     * @param obj
     * @return
     * @throws IllegalAccessException
     */
    public static Map<String, Object> objectToMap(Object obj) throws IllegalAccessException {
        Map<String, Object> map = new HashMap<String, Object>();
        Class<?> clazz = obj.getClass();
        for (Field field : clazz.getDeclaredFields()) {
            field.setAccessible(true);
            String fieldName = field.getName();
            Object value = field.get(obj);
            map.put(fieldName, value);
        }
        return map;
    }


    /**
     * map 转 实体类
     *
     * @param map
     * @return
     * @throws Exception
     */
    public User mapToBean(Map<String, Object> map)
            throws Exception {
        User permission = new User();
        if (map != null) {
            Field[] declaredFields = User.class.getDeclaredFields();
            if (declaredFields != null) {

                for (Field declaredField : declaredFields) {
                    declaredField.setAccessible(true);
                    Set<String> mapKeys = map.keySet();

                    for (String mapKey : mapKeys) {

                        if (declaredField.getType().toString().contains("Integer"))//判断属性类型 进行转换,map中存放的是Object对象需要转换 实体类中有多少类型就加多少类型,实体类属性用包装类;
                            if (declaredField.getName().equals(mapKey)) {
                                declaredField.set(permission, Integer.valueOf(map.get(mapKey).toString()));
                                break;
                            }
                        if (declaredField.getType().toString().contains("String"))//判断属性类型 进行转换;
                            if (declaredField.getName().equals(mapKey)) {
                                declaredField.set(permission, map.get(mapKey));

                                break;
                            }
                        if (declaredField.getType().toString().contains("Float"))//判断属性类型 进行转换;
                            if (declaredField.getName().equals(mapKey)) {
                                declaredField.set(permission, Float.valueOf(map.get(mapKey).toString()));

                                break;
                            }

                        if (declaredField.getType().toString().contains("Long"))//判断属性类型 进行转换;
                            if (declaredField.getName().equals(mapKey)) {
                                declaredField.set(permission, Long.valueOf(map.get(mapKey).toString()));
                                break;
                            }

                        if (declaredField.getType().toString().contains("Date"))//判断属性类型 进行转换;
                            if (declaredField.getName().equals(mapKey)) {
                                String s = map.get(mapKey).toString();
                                Date parse = parse(s, "EEE MMM dd HH:mm:ss zzz yyyy", Locale.US);
                                declaredField.set(permission, parse);
                                break;
                            }

                    }
                }
            }

        }

        return permission;
    }


    @Test
    public void getTime() throws ParseException {
        String str = "Tue Apr 06 08:00:00 CST 2021";
        Date date = parse(str, "EEE MMM dd HH:mm:ss zzz yyyy", Locale.US);

    }

    // 格林威治时间转Date
    private Date parse(String str, String pattern, Locale locale) {
        if (str == null || pattern == null) {
            return null;
        }
        try {
            return new SimpleDateFormat(pattern, locale).parse(str);
        } catch (ParseException e) {
            e.printStackTrace();
        }
        return null;
    }
}

9、那些转换方法都可以单独用

参考文章链接:

https://blog.csdn.net/qq_15204179/article/details/86677123

https://www.cnblogs.com/zktww/p/14296407.html

https://www.cnblogs.com/tobeymarshall/p/10217410.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/234450.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • volatile关键字作用与内存可见性、指令重排序概述[JAVA]「建议收藏」

    volatile关键字作用与内存可见性、指令重排序概述[JAVA]「建议收藏」在理解volotile关键字的作用之前,先粗略解释下内存可见性与指令重排序。1.内存可见性Java内存模型规定,对于多个线程共享的变量,存储在主内存当中,每个线程都有自己独立的工作内存,并且线程只能访问自己的工作内存,不可以访问其它线程的工作内存。工作内存中保存了主内存中共享变量的副本,线程要操作这些共享变量,只能通过操作工作内存中的副本来实现,操作完毕之后再同步回到主内存当中,其JVM内存模型大

  • trylock 用法_try可以没有catch吗

    trylock 用法_try可以没有catch吗tryLock的使用业务场景方法说明用法业务场景对于某些并发业务场景,我们可能想保证同一时刻只有一个线程在执行某一方法。例如:对于缓存的初始化工作,此时我们可以使用tryLock()方法对代码进行上锁,只有拿到锁的线程可以执行操作,而其他线程则只会在进行一次尝试后返回false。方法说明Acquiresthelockonlyifitisnotheldbyanotherthreadatthetimeofinvocation.只有在调用时它是空闲的才能获取锁。获取锁

    2022年10月15日
  • Windows编程(网络编程)

    Windows编程(网络编程)套接字类型与协议设置SOCK_STREAM[流套接字]TCP面向连接、可靠的数据传输适合传输大量的数据,不支持广播、多播SOCK_DGRAM[数据包套接字]

    2021年12月13日
  • 现有的人脸数据库介绍及下载链接

    现有的人脸数据库介绍及下载链接

  • Java虚拟机:对象的创建过程

    Java虚拟机:对象的创建过程

  • 【图文讲解】映射——单射-双射-满射概念

    【图文讲解】映射——单射-双射-满射概念最近看的一篇论文里出现了partialmap的概念,用我的散装英文乍一翻译——“部分映射”?印象中高中和大一的高数书里都讲过,但一些概念已经忘差不多了(罪过罪过–),索性重新熟悉一下。百度,发现“部分映射”这个词在百度词条里没能拥有百分百匹配的姓名。Wikipedia维基百科里给出的是一个很相似的英文词汇,partialfunction。以…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号