BeanCopyUtils.copyList(dataList, esClass)报错

com.alibaba.fastjson.JSONException: syntax error, expect {, actual string, pos 124, line 1, column 125[{"assetsId":"信息港二期监控点 5 GF01 F12","onlineType":1,"propertyNature":"1","propertyUnit":"中国移动","province":"北京市","stock":false,"type":3,"verified":false}]

	at com.alibaba.fastjson.parser.DefaultJSONParser.parseObject(DefaultJSONParser.java:205)
	at com.alibaba.fastjson.parser.DefaultJSONParser.parseObject(DefaultJSONParser.java:1149)
	at com.alibaba.fastjson.parser.DefaultJSONParser.parseObject(DefaultJSONParser.java:1154)
	at com.alibaba.fastjson.parser.deserializer.MapDeserializer.deserialze(MapDeserializer.java:23)
	at com.alibaba.fastjson.parser.deserializer.ContextObjectDeserializer.deserialze(ContextObjectDeserializer.java:9)
	at com.alibaba.fastjson.parser.deserializer.DefaultFieldDeserializer.parseField(DefaultFieldDeserializer.java:88)
	at com.alibaba.fastjson.parser.deserializer.JavaBeanDeserializer.parseField(JavaBeanDeserializer.java:1278)
	at com.alibaba.fastjson.parser.deserializer.JavaBeanDeserializer.deserialze(JavaBeanDeserializer.java:893)
	at com.alibaba.fastjson.parser.deserializer.JavaBeanDeserializer.parseRest(JavaBeanDeserializer.java:1624)
	at com.alibaba.fastjson.parser.deserializer.FastjsonASMDeserializer_1_DummyPointES.deserialze(Unknown Source)
	at com.alibaba.fastjson.parser.deserializer.JavaBeanDeserializer.deserialze(JavaBeanDeserializer.java:287)
	at com.alibaba.fastjson.parser.DefaultJSONParser.parseArray(DefaultJSONParser.java:792)
	at com.alibaba.fastjson.parser.DefaultJSONParser.parseArray(DefaultJSONParser.java:726)
	at com.alibaba.fastjson.parser.DefaultJSONParser.parseArray(DefaultJSONParser.java:721)
	at com.alibaba.fastjson.JSON.parseArray(JSON.java:643)
	at com.alibaba.fastjson.JSON.parseArray(JSON.java:623)
	at com.fzy.ifmscloud.sysresource.util.BeanCopyUtils.copyList(BeanCopyUtils.java:56)
	at com.fzy.ifmscloud.sysresource.util.ElasticsearchExportUtil.exportToElastic(ElasticsearchExportUtil.java:24)
	at com.fzy.ifmscloud.sysresource.rest.elasticsearch.ElasticSearchController.PageExport(ElasticSearchController.java:291)
	at com.fzy.ifmscloud.sysresource.rest.elasticsearch.ElasticSearchController.exportAllDummyPointES(ElasticSearchController.java:225)
	at com.fzy.ifmscloud.sysresource.SystemResourceTest.exportAllDummyPointES(SystemResourceTest.java:334)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:59)
	at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
	at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:56)
	at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
	at org.springframework.test.context.junit4.statements.RunBeforeTestExecutionCallbacks.evaluate(RunBeforeTestExecutionCallbacks.java:74)
	at org.springframework.test.context.junit4.statements.RunAfterTestExecutionCallbacks.evaluate(RunAfterTestExecutionCallbacks.java:84)
	at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:75)
	at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86)
	at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84)
	at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:366)
	at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:251)
	at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:97)
	at org.junit.runners.ParentRunner$4.run(ParentRunner.java:331)
	at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:79)
	at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:329)
	at org.junit.runners.ParentRunner.access$100(ParentRunner.java:66)
	at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:293)
	at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
	at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70)
	at org.junit.runners.ParentRunner$3.evaluate(ParentRunner.java:306)
	at org.junit.runners.ParentRunner.run(ParentRunner.java:413)
	at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:190)
	at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
	at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:69)
	at com.intellij.rt.junit.IdeaTestRunner$Repeater$1.execute(IdeaTestRunner.java:38)
	at com.intellij.rt.execution.junit.TestsRepeater.repeat(TestsRepeater.java:11)
	at com.intellij.rt.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:35)
	at com.intellij.rt.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:232)
	at com.intellij.rt.junit.JUnitStarter.main(JUnitStarter.java:55)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at com.intellij.rt.execution.CommandLineWrapper.main(CommandLineWrapper.java:65)

方法内容如下:

    public static <S, T> List<T> copyList(List<S> sourceList, Class<T> clazz) {
        if (CollectionUtils.isEmpty(sourceList)) {
            return new ArrayList<>();
        }
        return JSONArray.parseArray(JSON.toJSONString(sourceList), clazz);
    }

报错原因是转json的时候字段名一样但是格式不对,比如:

原字段:

private ObjectdynamicField;

目标字段:
private JSONObject dynamicField;

这就是字段名一样,但是格式不一样,导致报错
不够细心!

注:一类基本类型是能够通过json转的,比如String "0.123456"能转为Double 0.123456

在使用 EasyExcel 的 `write` 方法时,如果没有正确传递类参数(class parameter),确实可能会导致错误。EasyExcel 是一个基于 Java 的库,主要用于简化 Excel 文件的读写操作,尤其适用于大数据量场景下的内存优化处理[^1]。 ### 错误原因 当调用 `EasyExcel.write()` 方法时,如果不传递用于映射 Excel 表格字段的类(即数据模型类),EasyExcel 将无法确定如何将 Java 对象转换为 Excel 行记录。这种情况下,程序会抛出异常或警告,提示缺少必要的类信息来执行写入操作。 例如,以下代码片段会导致错误: ```java EasyExcel.write().head(head).sheet("Sheet1").doWrite(dataList); ``` 上述代码中,`EasyExcel.write()` 没有指定任何类信息,这会导致 EasyExcel 无法构建正确的写入上下文,进而引发运行时异常。 ### 解决方案 要解决这个问题,需要确保在调用 `write` 方法时提供一个明确的数据模型类,或者通过其他方式指定字段映射关系。以下是几种常见的解决方案: #### 1. 提供数据模型类 推荐的做法是定义一个 POJO 类来描述 Excel 中每一行的结构,并将其作为参数传递给 `write` 方法: ```java // 定义数据模型类 public class DemoData { @ExcelProperty("姓名") private String name; @ExcelProperty("年龄") private int age; // Getter 和 Setter 方法 } // 写入操作 EasyExcel.write(fileName, DemoData.class).sheet("Sheet1").doWrite(dataList); ``` 在这个例子中,`DemoData.class` 被用来指导 EasyExcel 如何将对象列表 `dataList` 映射到 Excel 文件中。 #### 2. 使用 Map 代替实体类 如果不想使用固定的类结构,也可以选择使用 `Map<String, Object>` 来动态表示每一行的数据: ```java EasyExcel.write(fileName, Map.class).head(head).sheet("Sheet1").doWrite(dataList); ``` 这里 `head` 可以是一个 `List<List<String>>` 或 `List<String>`,用于定义 Excel 表头内容。 #### 3. 自定义列映射 对于更复杂的场景,可以通过实现 `WriteHandler` 接口来自定义列映射逻辑,但这通常适用于高级用户或特殊需求。 ### 注意事项 - 确保数据模型类中的字段与 Excel 列名相对应,可以通过 `@ExcelProperty` 注解来指定对应的列名。 - 如果使用的是 Map 方式,确保 `head` 参数与实际数据中的键匹配。 - 避免直接跳过类参数的传递,因为这是触发错误的主要原因。 通过以上方法可以有效避免因未传递类参数而导致的错误,同时也能提升代码的可维护性和灵活性。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值