java导出导入csv文件代码

 导出
        FileOutputStream fos = new FileOutputStream(
                "E:\\wendang" + "结算数据".concat(DateUtil.formatDateByYYYYMMdd(request.getStartDate())).concat("_")
                        .concat(DateUtil.formatDateByYYYYMMdd(request.getEndDate())).concat(".csv"));
        // 写入bom头 用于excel中文查看
        byte[] uft8bom = { (byte) 0xef, (byte) 0xbb, (byte) 0xbf };
        fos.write(uft8bom);
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(fos, "UTF-8"));
        bw.write("放款日期,订单号,总金额,还款期数");
        bw.newLine();

bw.close();

 

导入

@ApiOperation(value = "上传文件")
@PostMapping(value = "/writeupload", produces = "application/json; charset=utf-8")
public @ResponseBody BaseResponse writeoffupload(MultipartFile file, final HttpServletResponse resp) {

    log.info("writeupload-----》begin");
    String fileName = file.getOriginalFilename();
    log.info("fileName=={}", fileName);
    BaseResponse result = new BaseResponse();
    String ossFileName = CommonConstants.TEMP_PATH + DateUtil.parseDateByYYYYMMddhhmmss(new Date()) + fileName;
       BufferedOutputStream bos = null;
    BufferedReader reader=null;
    File localFile=null;
    try {
        SecurityUtils.getSubject().checkPermission(PermissionConstant.REPAYMENT_PLAN);
        String operatePeople = (String) SecurityUtils.getSubject().getPrincipal();
        log.info("operatePeople为==={}", operatePeople);
        ValidatorUtil.validateNotNull(operatePeople, "操作人为空");
        //读取文件并保存
        File path=new File(CommonConstants.TEMP_PATH);
        if (!path.exists()) {
            path.mkdirs();
        }
        localFile = new File(ossFileName);
        if (!localFile.exists()) {
            boolean isMake = localFile.createNewFile();
            if (!isMake) {
                result.setResponseCode(CommonResult.PROCESSING.getCode());
                result.setResponseMessage(CommonResult.PROCESSING.getMessage());
                return result;
            }
        }
        file.transferTo(localFile);
        List<String> repayNoList = Lists.newArrayList();
          reader = new BufferedReader(new FileReader(localFile));
        log.info("firstLine=="+reader.readLine());
        boolean flag=true;
        while(flag){
            String line = reader.readLine();
            if(null==line){
                flag=false;
            }else{
                line= line.replaceAll("\"","");
                Pattern p = Pattern.compile("\\s*|\t|\r|\n");
                Matcher m = p.matcher(line);
                String dest = m.replaceAll("");
                repayNoList.add(dest);
            }
        };
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值