如何在Java中将MultiPartfile传递给Reader?

6

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

我想从文件中读取并将其值分配给我的对象。我的CSV文件如下:

发送方账户,接收方账户,金额,日期

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

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;
    }

1
它在哪里抛出了NPE?你能提供一个堆栈跟踪吗? - Sean Carroll
2018-07-28 00:45:56.274 WARN 2960 --- [nio-8080-exec-9] .m.m.a.ExceptionHandlerExceptionResolver : 处理程序执行引起的异常已解决:java.lang.NullPointerException我认为问题出在这里,它无法读取文件 Reader in = new InputStreamReader(BankAccount.class.getClassLoader().getResourceAsStream(file.getOriginalFilename())); - Alpcan Yıldız
有没有办法直接传递文件本身而不是文件名? - Alpcan Yıldız
BankAccount.class.getClassLoader().getResourceAsStream 寻找与您的应用程序捆绑在一起的资源(在 .jar 或 .war 中)。如果用户提交了一个文件,那么很不可能您的应用程序会捆绑一个内部路径完全匹配所提交文件的资源。 - VGR
是的,你说得完全正确!我已经找到了解决方案。谢谢你的评论。 - Alpcan Yıldız
3个回答

14

上工作时,我编写了这段代码片段。

public void some(final MultipartFile file) {
  ...
  Reader reader = new InputStreamReader(file.getInputStream());
  CSVReader csvReader = new CSVReaderBuilder(reader).withSkipLines(1).build();
  ...
}

用于读取文件的库:

<dependency>
  <groupId>com.opencsv</groupId>
  <artifactId>opencsv</artifactId>
  <version>4.4</version>
</dependency>

4
CSVParser parserr = CSVParser.parse(is, StandardCharsets.US_ASCII,
            CSVFormat.EXCEL.withHeader());

好的,我找到了。谢谢!

1
嘿,伙计。感谢你的帮助!你应该将这个标记为正确答案。 - ygorazevedo

0

我认为这是读取multipartFile的最佳方式

  private static final CsvMapper mapper = new CsvMapper();

  public static <T> List<T> readCsvFile(MultipartFile file, Class<T> clazz) throws IOException {
    InputStream inputStream = file.getInputStream();
    CsvSchema schema = mapper.schemaFor(clazz).withHeader().withColumnReordering(true);
    ObjectReader reader = mapper.readerFor(clazz).with(schema);
    return reader.<T>readValues(inputStream).readAll();
}

使用jackson-dataformat-csv

<dependency>
    <groupId>com.fasterxml.jackson.dataformat</groupId>
    <artifactId>jackson-dataformat-csv</artifactId>
    <version>2.8.6</version>
</dependency>

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接