首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在Java中将MultiPartfile赋给Reader?

如何在Java中将MultiPartfile赋给Reader?
EN

Stack Overflow用户
提问于 2018-07-28 05:28:23
回答 2查看 8.3K关注 0票数 3

我将MultiPartFile作为参数传递给我的函数,并使用CSVFormat读取,但它给了我空指针异常,这是我的代码。

我想从文件中读取并将该值赋给我的对象。我的CSV文件如下所示:

发送方帐户、接收方帐户、金额、日期

123,654321,100,19-07-2018 12:13:00

代码语言:javascript
复制
public List<BankAccount> readCsv(MultipartFile file) throws IOException {
        List<BankAccount> bankAccountList = new ArrayList<BankAccount>();

        DateTimeFormatter dtf = DateTimeFormatter.ofPattern("dd-MM-yyyy HH:mm:ss");



        Reader in = new InputStreamReader(BankAccount.class.getClassLoader()
                .getResourceAsStream(file.getOriginalFilename()));

        Iterable<CSVRecord> parser = CSVFormat.EXCEL.withHeader("Sender account","Receiver Account","Amount","Date").parse(in);


            for (CSVRecord csvRecord : parser) {
            BankAccount bankAccount = new BankAccount();
            String senderAccount = csvRecord.get("Sender account");
            String receiverAccount = csvRecord.get("Receiver account");
            float amount = Float.parseFloat(csvRecord.get("Amount"));
            ZonedDateTime date = LocalDateTime.parse(csvRecord.get("Date"), dtf)
                    .atZone(ZoneId.of("Asia/Istanbul"));
            bankAccount.setFromId(senderAccount);
            bankAccount.setToId(receiverAccount);
            bankAccount.setDate(date);
            bankAccount.setBalance(amount);
            bankAccountList.add(bankAccount);
        }

        return bankAccountList;
    }
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-07-28 05:56:48

代码语言:javascript
复制
CSVParser parserr = CSVParser.parse(is, StandardCharsets.US_ASCII,
            CSVFormat.EXCEL.withHeader());

好的,我创建了它。谢谢!

票数 3
EN

Stack Overflow用户

发布于 2019-01-05 07:15:16

spring-boot上工作时,我写了这段代码。

代码语言:javascript
复制
public void some(final MultipartFile file) {
  ...
  Reader reader = new InputStreamReader(file.getInputStream());
  CSVReader csvReader = new CSVReaderBuilder(reader).withSkipLines(1).build();
  ...
}

用于读取csv的库

代码语言:javascript
复制
<dependency>
  <groupId>com.opencsv</groupId>
  <artifactId>opencsv</artifactId>
  <version>4.4</version>
</dependency>
票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51565799

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档