• 对上传的excel进行读取操作(SpringBoot Mybatis-Plus)


    gradle

    compile group: 'org.apache.poi', name: 'poi', version: '3.9';
    compile group: 'org.apache.poi', name: 'poi-excelant', version: '3.9';
    compile group: 'org.apache.poi', name: 'poi-scratchpad', version: '3.9';
    

    Controller

    @PostMapping(value = "/excelImport")
        @ResponseBody
        public HttpResult excelImport(@RequestParam("file") MultipartFile multipartFile, @RequestParam("deptId") Long deptId) throws IOException, InterruptedException {
            String fileName = multipartFile.getOriginalFilename();
            if (!fileName.endsWith("xlsx") && !fileName.endsWith("xls")) {
                return HttpResult.error("请上传excel文件");
            }
    
            String result = sysSubjectService.excelImport(multipartFile);
    
            if (!"succeed".equals(result)) {
                return HttpResult.error(result);
            }
    
            return HttpResult.ok(result);
        }
    

    Service

    @Override
        public String excelImport(MultipartFile multipartFile) throws IOException {
            String fileName = multipartFile.getOriginalFilename();
    
            Workbook workbook = null;
            InputStream is = multipartFile.getInputStream();
            if (fileName.endsWith("xlsx")) {
                workbook = new XSSFWorkbook(is);
            }
            if (fileName.endsWith("xls")) {
                workbook = new HSSFWorkbook(is);
            }
    
            if (workbook != null) {
                List<SysSubject> subjectList = new ArrayList<>();
                //读取第一个sheet
                Sheet sheet = workbook.getSheetAt(0);
                for (int rowIndex = 1; rowIndex <= sheet.getLastRowNum(); rowIndex++) {
                    SysSubject sysSubject = new SysSubject();
    
                    // XSSFRow 代表一行数据
                    Row row = sheet.getRow(rowIndex);
                    //获取单元格信息
                    Cell dateCell = row.getCell(0);
                    dateCell.setCellType(Cell.CELL_TYPE_STRING);
                    String code = ExcelCellToStringUtil.getStringCellValue(dateCell);
                    code = code.replaceAll("\s*", "").replaceAll("[\u00A0]+", "");
                    //防空异常 必加
                    if (null == code || "".equals(code)) {
                        continue;
                    }
    
                    //科目代码
                    sysSubject.setCode(code);
    
                    subjectList.add(sysSubject);
                }
    
                sysSubjectMapper.insertBatchSubject(tableName, subjectList);
    
            }
            return "succeed";
        }
    

    RedisUtils

    package cn.edu.qfnu.soft.common.util;
    
    import java.io.Serializable;
    import java.util.List;
    import java.util.Set;
    import java.util.concurrent.TimeUnit;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.data.redis.core.HashOperations;
    import org.springframework.data.redis.core.ListOperations;
    import org.springframework.data.redis.core.RedisTemplate;
    import org.springframework.data.redis.core.SetOperations;
    import org.springframework.data.redis.core.ValueOperations;
    import org.springframework.data.redis.core.ZSetOperations;
    import org.springframework.stereotype.Service;
    
    /**
     * redis操作工具类
     * @author 吕嘉鸣
     */
    @Service
    public class RedisUtils {
        @Autowired
        private RedisTemplate redisTemplate;
    
        /**
         * 写入缓存
         *
         * @param key
         * @param value
         * @return
         */
        public boolean set(final String key, Object value) {
            boolean result = false;
            try {
                ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();
                operations.set(key, value);
                result = true;
            } catch (Exception e) {
                e.printStackTrace();
            }
            return result;
        }
    
        /**
         * 写入缓存设置时效时间
         *
         * @param key
         * @param value
         * @return
         */
        public boolean set(final String key, Object value, Long expireTime, TimeUnit timeUnit) {
            boolean result = false;
            try {
                ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();
                operations.set(key, value);
                redisTemplate.expire(key, expireTime, timeUnit);
                result = true;
            } catch (Exception e) {
                e.printStackTrace();
            }
            return result;
        }
    
        /**
         * 批量删除对应的value
         *
         * @param keys
         */
        public void remove(final String... keys) {
            for (String key : keys) {
                remove(key);
            }
        }
    
        /**
         * 批量删除key
         *
         * @param pattern
         */
        public void removePattern(final String pattern) {
            Set<Serializable> keys = redisTemplate.keys(pattern);
            if (keys.size() > 0) {
                redisTemplate.delete(keys);
            }
        }
    
        /**
         * 删除对应的value
         *
         * @param key
         */
        public void remove(final String key) {
            if (exists(key)) {
                redisTemplate.delete(key);
            }
        }
    
        /**
         * 判断缓存中是否有对应的value
         *
         * @param key
         * @return
         */
        public boolean exists(final String key) {
            return redisTemplate.hasKey(key);
        }
    
        /**
         * 读取缓存
         *
         * @param key
         * @return
         */
        public Object get(final String key) {
            Object result = null;
            ValueOperations<Serializable, Object> operations = redisTemplate.opsForValue();
            result = operations.get(key);
            return result;
        }
    
        /**
         * 哈希 添加
         *
         * @param key
         * @param hashKey
         * @param value
         */
        public void hmSet(String key, Object hashKey, Object value) {
            HashOperations<String, Object, Object> hash = redisTemplate.opsForHash();
            hash.put(key, hashKey, value);
        }
    
        /**
         * 哈希获取数据
         *
         * @param key
         * @param hashKey
         * @return
         */
        public Object hmGet(String key, Object hashKey) {
            HashOperations<String, Object, Object> hash = redisTemplate.opsForHash();
            return hash.get(key, hashKey);
        }
    
        /**
         * 列表添加
         *
         * @param k
         * @param v
         */
        public void lPush(String k, Object v) {
            ListOperations<String, Object> list = redisTemplate.opsForList();
            list.rightPush(k, v);
        }
    
        /**
         * 列表获取
         *
         * @param k
         * @param l
         * @param l1
         * @return
         */
        public List<Object> lRange(String k, long l, long l1) {
            ListOperations<String, Object> list = redisTemplate.opsForList();
            return list.range(k, l, l1);
        }
    
        /**
         * 集合添加
         *
         * @param key
         * @param value
         */
        public void add(String key, Object value) {
            SetOperations<String, Object> set = redisTemplate.opsForSet();
            set.add(key, value);
        }
    
        /**
         * 集合获取
         *
         * @param key
         * @return
         */
        public Set<Object> setMembers(String key) {
            SetOperations<String, Object> set = redisTemplate.opsForSet();
            return set.members(key);
        }
    
        /**
         * 有序集合添加
         *
         * @param key
         * @param value
         * @param scoure
         */
        public void zAdd(String key, Object value, double scoure) {
            ZSetOperations<String, Object> zset = redisTemplate.opsForZSet();
            zset.add(key, value, scoure);
        }
    
        /**
         * 有序集合获取
         *
         * @param key
         * @param scoure
         * @param scoure1
         * @return
         */
        public Set<Object> rangeByScore(String key, double scoure, double scoure1) {
            ZSetOperations<String, Object> zset = redisTemplate.opsForZSet();
            return zset.rangeByScore(key, scoure, scoure1);
        }
    }
    

    ExcelCellToStringUtil

    package cn.edu.qfnu.soft.common.util;
    
    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.DataFormatter;
    /**
     * excel单元格数据工具类
     * @author ljm
     */
    public class ExcelCellToStringUtil {
        /**
         * 获取excel单元格数据内容中为字符串类型的数据
         * @author ljm
         * @param cell
         * @return
         */
        public static String getStringCellValue(Cell cell)
        {
            String strCell = "";
            if(cell == null)
            {
                return "";
    
            }else{
                //判断数据的类型
                switch (cell.getCellType()){
                    case Cell.CELL_TYPE_NUMERIC: //数字
                        DataFormatter dataFormatter = new DataFormatter();
    
                        strCell = dataFormatter.formatCellValue(cell);
                        break;
                    case Cell.CELL_TYPE_STRING: //字符串
                        strCell = String.valueOf(cell.getStringCellValue());
                        break;
                    case Cell.CELL_TYPE_BOOLEAN: //Boolean
                        strCell = String.valueOf(cell.getBooleanCellValue());
                        break;
                    case Cell.CELL_TYPE_FORMULA: //公式
                        strCell = String.valueOf(cell.getCellFormula());
                        break;
                    case Cell.CELL_TYPE_BLANK: //空值
                        strCell = "";
                        break;
                    case Cell.CELL_TYPE_ERROR: //故障
                        strCell = "非法字符";
                        break;
                    default:
                        strCell = "未知类型";
                        break;
                }
            }
            if("".equals(strCell)||strCell==null)
            {
                return "";
            }
            return strCell;
        }
    }
    
    
  • 相关阅读:
    Microsoft Updateclient更新
    DataTables warning: table id=dataTable
    BCB使用线程删除目录中的图片
    grep常见使用方法总结
    实战:percona-xtrabackup 2.1.9 for mysql 5.6.19
    代理模式之cglib动态代理
    hello world to php( mac 配置 xmapp virtual host)
    Android开发之AlarmManager具体解释
    linux入门教程(六) Linux文件与目录管理
    linux入门教程(五) Linux系统的远程登录
  • 原文地址:https://www.cnblogs.com/ideaAI/p/14751756.html
Copyright © 2020-2023  润新知