IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> Easyexcel读取excel表地理位置数据,按中文拼音排序 -> 正文阅读

[开发测试]Easyexcel读取excel表地理位置数据,按中文拼音排序

使用Easyexcel读取excel文件

EasyExcel是一个基于Java的简单、省内存的读写Excel的开源项目。
官网:https://www.yuque.com/easyexcel/doc/easyexcel

1.maven导入

<dependency>
   <groupId>com.alibaba</groupId>
   <artifactId>easyexcel</artifactId>
   <version>3.0.5</version>
</dependency>

2.创建实体类

注解中的名称应与excel表头的名称一致
excel表
在这里插入图片描述
3.创建实体类

@Data
public class WeatherExcelData {
    @ExcelProperty("Location_ID")
    private String Location_ID;

    /**
     * 地区名
     */
    @ExcelProperty("Location_Name_ZH")
    private String locationName;
    /**
     * 一级地区名
     */
    @ExcelProperty("Adm1_Name_ZH")
    private String primaryArea;
    /**
     * 二级地区名
     */
    @ExcelProperty("Adm2_Name_ZH")
    private String SecondArea;
}

4.使用easyexcel读取excel文件后,存入缓存。使用Collator类,重写compare比较方法。使用stream流根据一级地区名,二级地区名分组排序。
此处使用easyexcel最简单的读,更多使用方式可查询官网

public class ResourceController {
    private static Map<String, WeatherExcelData> locationMap = new HashMap<>();
    private static List<WeatherExcelData> locationList = new ArrayList<>();
    private static TreeMap<String, Map<String, List<WeatherExcelData>>> treeMap = new TreeMap();


    public void getExcel(){
        try{
        	// excel文件放于resources文件夹下,通过ClassPathResource形式读取,打包后放置linux环境下也可正常读取数据
            ClassPathResource resource = new ClassPathResource("China-City-List-latest.xlsx");
            // 这里 需要指定读用哪个class去读,然后读取第一个sheet 文件流会自动关闭
            // 这里每次会读取3000条数据 然后返回过来 直接调用使用数据就行
            EasyExcel.read(resource.getInputStream(), WeatherExcelData.class, new PageReadListener<WeatherExcelData>(dataList -> {
                for (WeatherExcelData data : dataList) {
                    locationMap.put(data.getLocationName() + "", data);
                }
                locationList.addAll(dataList);
            })).sheet().doRead();

            putLocationCache(locationList);
        }catch (Exception e){
            log.error("读取地区文件错误");
        }
    }

    /**
     * 缓存地理位置
     */
    public void putLocationCache(List<WeatherExcelData> locationList) {
        if(locationList.size() == 0){
            return;
        }

        TreeMap<String, Map<String, List<WeatherExcelData>>> newLocation = new TreeMap<>(new Comparator<Object>() {
        	// 设置Locale.CHINA按中文排序
            Collator collator = Collator.getInstance(Locale.CHINA);

            @Override
            public int compare(Object  object1, Object  object2) {
                if (object1 == null || object2 == null){
                    return 0;
                }
                CollationKey keyOne = collator.getCollationKey(String.valueOf(object1));
                CollationKey keyTwo = collator.getCollationKey(String.valueOf(object2));
                return keyOne.compareTo(keyTwo);
            }
        });

        // 转化为TreeMap,先按一级地区名,再按二级地区名分组排序
        Map<String, Map<String, List<WeatherExcelData>>> location = locationList.stream()
                .collect(Collectors.groupingBy(WeatherExcelData::getPrimaryArea,
                        Collectors.groupingBy(WeatherExcelData::getSecondArea, Collectors.toList())));
        for (Map.Entry<String, Map<String, List<WeatherExcelData>>> entry : location.entrySet()) {
            newLocation.put(entry.getKey(), entry.getValue());
        }

        treeMap = newLocation;
        System.out.println(treeMap);
    }
}
  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2022-04-24 09:45:10  更:2022-04-24 09:45:36 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 3:16:03-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码