我有一个包含“否”和“日期”的表格。这将是动态形式。在Spring Boot JPA中进行批处理更新时,出现了“
java.time.format.DateTimeParseException:无法解析文本‘03 / 03 / 2020,03 /
03/2020’,在索引10处找到了未解析的文本”的异常
@RequestMapping(value="/abcpage", produces = { MediaType.APPLICATION_JSON_VALUE })
public String savePurchaseEntries(@ModelAttribute ABC abc,HttpSession session)
{
System.out.println(abc);
DateTimeFormatter dateTimeFormatter = DateTimeFormatter.ofPattern("dd/MM/yyyy");
LocalDate today = LocalDate.parse(abc.getDate(),dateTimeFormatter);
abc.setLoclaDate(today);
return "redirect:/home";
}
在这里,ABC是实体类,我可以以dd / mm / yyyy格式获取日期值,并将其转换为localdate并设置为实体。
ABC[NO=101,102,date=03/03/2020,03/03/2020]
对于一个条目,它工作正常,但是在批量处理时,它将引发异常。
@Entity
class ABC{
@column(name="NO")
private String NO;
@Transient
private String date;
@Column(name="invdate")
private LocalDate loclaDate;
//getters & setters//tostring
}
我认为您的代码存在问题,如果我正确理解了您的输入,便是您在中传递了逗号(,)分隔的日期字符串LocalDate.parse(abc.getDate(),dateTimeFormatter)
。
您每次都需要传递一个日期到parse()方法,因为它试图使用日期格式器格式格式化提供的字符串输入,因此当在“
03/03/2020”的输入中遇到逗号(,)时发生错误, 03/03/2020”。
请参考官方文档。
您可以尝试以下操作:
String[] inputDates = abc.getDate().split[","];
for (String date : inputDates) {
// you can now use LocalDate.parse(abc.getDate(),dateTimeFormatter) here
// write your logic here.
}
我希望这可以帮助您消除疑虑,如果不让我知道您的确切问题,我会尽力帮助您。
编辑1 用于插入数据
下面是一种插入数据的方法,
创建一个表,该表将存储具有3列的日期-
id(PK),abc_id(ABC表的FK参考),日期(此处存储单个日期)。现在,假设上表的名称是abc_date_map,然后在您的ABC实体中将该实体称为OneToMany。像下面一样
@Entity
class ABC {
@Column(name="NO")
private String NO;
@Transient
private String date;
@Column(name="abc_date_map_id")
private List<AbcDateMap> abcDateMapEntityList;
//getters & setters//tostring
}
您的AbcDateMap实体将像
@Entity
public class AbcDateMap{
@Column(name="abc_id")
private Integer abcId;
@Column(name="date")
private LocalDate localDate;
// getters setters
}
您的实体插入逻辑将类似于:
public Long insert(ABC abc) {
abc.setNo(/*something*/);
List<AbcDateMap> l = new ArrayList<>();
AbcDateMap abcDate = new AbcDateMap();
for (String date : abc.getDate().split(",")) {
abcDate.setLocalDate(/*parse date here and store*/);
abcDate.setAbcId(abc.getId());
}
abc.setAbcDateMapEntityList(l);
repo.save(abc);
}
现在,上面的代码不是确切的代码,您将不得不对其进行完善,可能会出现语法/语义错误。另外,您将需要根据需要进行更改。
希望对您有帮助。
祝你好运,学习愉快!
我正在尝试解析这样的日期: 该日期是来自远程服务的响应。我并不是真的期望Z,我也不是真的需要它,所以我想知道处理这个案件的正确方法是什么。
我使用Java8来解析日期并找出两个日期之间的差异。 以下是我的片段: 当我运行时,我得到了错误: java.time.format.DateTimeParseException:无法在索引3解析文本
下面是我的字符串:convertdate:'2016-08-18 14:27:15.103+02' 和我的代码: 我想不是太复杂,买我看不出错误。字符串中的+02可能是原因吗?
Im使用Python3.6 tensorflow 1.5 Im跟踪链接 但我得到了一个错误: doe@doe:~/anaconda3/envs/tenorflow/模型/研究/object_detection$python3train.py--logtostderr-train_dir=训练/-pipeline_config_path=训练/ssd_mobilenet_v1_coco.config
输入文本为2020年2月20日 以下代码块抛出,其中包含无法分析的消息文本“28Feb2020”,在索引7中找到未分析的文本:
In[1]: import pandas as pd import numpy as np from IPython.display import display pd.options.display.max_columns = 50 1. 规划数据分析路线 # 读取查看数据 In[2]: college = pd.read_csv('data/col