读取远程上CSV文件,并存储于本地数据库

需求:读取远程http路径下的csv文件,将部分字段存储在数据库中

pom文件

<!-- https://mvnrepository.com/artifact/net.sourceforge.javacsv/javacsv -->
		<dependency>
			<groupId>net.sourceforge.javacsv</groupId>
			<artifactId>javacsv</artifactId>
			<version>2.0</version>
		</dependency>

 csv文件读取并存储于数据库中

public void csvRead(String libCode, String httpUrl) {
        CsvReader reader = null;
        try {
            URL url = new URL(httpUrl);
            HttpURLConnection connection = (HttpURLConnection) url.openConnection();
            DataInputStream inputStream = new DataInputStream(connection.getInputStream());
            
            reader = new CsvReader(inputStream, ',', Charset.forName("GBK"));
            //跳过第一行
            reader.readHeaders();
            Integer weekDay = null;
            List<HistoryVehiclePassDO> historyVehiclePassDOList = new ArrayList<>();
            String lineTxt = null;
            String[] columns = null;
            String timeSlot = null;
            Date date = null;
            SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
            while (reader.readRecord()) {
                HistoryVehiclePassDO historyVehiclePassDO = new HistoryVehiclePassDO();
                lineTxt = reader.getRawRecord();
                lineTxt = lineTxt.replace("\t", "");
                lineTxt = lineTxt.replace("\"", "");
                columns = lineTxt.split(",");
                if (!isTimeLegal(columns[2])) {
                    continue;
                }
                historyVehiclePassDO.setVehicleNo(columns[0]);
                historyVehiclePassDO.setCrossName(columns[1]);
                date = dateFormat.parse(columns[2]);
                historyVehiclePassDO.setTimeDate(date);
                weekDay = dateToWeek(columns[2]);
                historyVehiclePassDO.setWeekDay(weekDay);
                timeSlot = columns[2].substring(11, 13);
                historyVehiclePassDO.setTimeSlot(Integer.parseInt(timeSlot));
                historyVehiclePassDO.setLibCode(libCode);
                historyVehiclePassDOList.add(historyVehiclePassDO);
//BusinessConstant.BATCH_NUM为常量1000,意思是list集合每满1000,存储一次
//JPA的saveAll方法
                if (historyVehiclePassDOList.size() % BusinessConstant.BATCH_NUM == 0) {
                    historyVehiclePassRepository.saveAll(historyVehiclePassDOList);
                    historyVehiclePassDOList.clear();
                }
            }
//储存剩余的行
            historyVehiclePassRepository.saveAll(historyVehiclePassDOList);
            historyVehiclePassDOList.clear();
            reader.close();
            inputStream.close();
        } catch (FileNotFoundException e) {
            LOGGER.error(HikLog.toLog(ErrorCodes.FIlE_NOT_FIND.getCode(), ErrorCodes.FIlE_NOT_FIND.getMessage()));
            e.printStackTrace();
        } catch (IOException e) {
            LOGGER.error(HikLog.toLog(ErrorCodes.CSV_READ_ERROR.getCode(), ErrorCodes.CSV_READ_ERROR.getMessage()));
            LOGGER.error("IOException:" + e.getMessage());
            e.printStackTrace();
        } catch (ParseException e) {
            LOGGER.error(HikLog.toLog(ErrorCodes.TIME_PARSE_ERROR.getCode(), ErrorCodes.TIME_PARSE_ERROR.getMessage()));
            e.printStackTrace();
        }
    }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值