目前发现,一些excel导入校验时,容易出现不可见字符引起的类型转换异常,这种情况,一般的方式不能发现问题。
例如:图中的数值要以数值格式存表,但系统转换为double类型失败,即使trim()了也一样。debug时人眼也看不出问题来
报错如下:
[2023-03-29 11:51:36.867] [http-nio-9099-exec-5] ERROR l.m.s.s.Impl.SalesOrderServiceImpl : For input string: "166.99"
java.lang.NumberFormatException: For input string: "166.99"
at sun.misc.FloatingDecimal.readJavaFormatString(FloatingDecimal.java:2043)
这些数值即使在记事本,notepad++里也看不出问题来
最后是在everedit里才明显看到了166.99前面存在特殊符号。
复制到idea中可看出这些特殊符号就是\u200E
这条数据的来源已经不可知了,大概率是复制粘贴引起的。
这种问题其实很常见,比如新建一个文档,查看属性,复制其中的时间
表面看是正常的,其实这里掺杂了好几个不可见字符
总之,注意避坑