我正在使用 parallelStream() 解析 CSV 文件,并注意到一些奇怪的行为。有问题的代码在这里:
public List<AddressRaw> parseAddress(List<CSVRecord> records) {
return records.subList(1, records.size())
.parallelStream()
.flatMap(record -> {
// There should only be 10 columns in the CSV
if (record.size() > 10) {
log.error("Too many columns were detected on row number " + record.getRecordNumber());
throw new IllegalArgumentException("Too many columns were detected on row number " + record.getRecordNumber());
}
我调用上述方法的控制器:
try {
// csv files are identified by either text/csv or application/vnd.ms-excel
if (file.isEmpty() || Objects.isNull(file.getContentType()) || !(file.getContentType().equals("text/csv") || file.getContentType().equals("application/vnd.ms-excel"))) {
log.error("File uploaded is not a csv");
throw new BadRequestException("File uploaded is not a csv");
}
List<CSVRecord> records = CSVHelper.recordsFromBytes(file.getBytes());
// convert the rows into a format mirroring a db transit time
List<AddressRaw> rawAddresss = addressService.parseAddress(records);
if (rawAddresss.isEmpty()) {
throw new BadRequestException("No addresses found");
}
// execute the upsert in batches (Upserts count as two changes, as the insert fails then an update occurs)
Integer addressesInserted = addressService.batchInsertAddresses(rawAddresss, targetUserId);
LocalDateTime end = LocalDateTime.now();
log.info("Upserted {} AddressRaw records in: {}ms", addressesInserted, start.until(end, ChronoUnit.MILLIS));
return ResponseEntity.ok(addressesInserted);
} catch (IOException e) {
log.error("Unable to parse csv file: ", e);
} catch (DataAccessException e) {
log.error("Unable to execute SQL: ", e);
}
例如,有时我在前端得到的错误是“在第 3 行检测到太多列”,这是我所期望的。有时我得到的错误是“java.lang.IllegalArgumentException:在第 3 行检测到太多列”,我不确定为什么它也会打印出异常名称?我在这里缺少什么吗?