- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
csv全称“Comma-Separated Values”,是一种逗号分隔值格式的文件,是一种用来存储数据的纯文本格式文件。CSV文件由任意数目的记录组成,记录间以某种换行符分隔;每条记录由字段组成,字段间的分隔符是其它字符或字符串。
我找了找目前百度上基本是没有这方面的快捷转换方式和工具包,能找到的基本都不能通用写死的,没办法只能自己写一份出来,主要用到的技术,反射,泛型,类型转换,构造者设计模式
,以下代码给提供一个思路,技术差不多的话基本上看了下面的代码是能自己写出来的,如果是入门级别的Java程序员就自行跳过本博客
部分工具类的代码没有展示, 这里就粘贴主要核心原理,很简单,自己也是能编写出来的
package com.file.csv;
import com.obj.converter.Converter;
import com.reflect.ReflectUtil;
import com.string.PatternCommon;
import lombok.SneakyThrows;
import org.springframework.core.ParameterizedTypeReference;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
/**
* csv转对象
* @Author: huanmin
* @Date: 2022/6/18 15:59
* @Version: 1.0
* @Description: 文件作用详细描述....
*/
public class CSVToObj<T> extends ParameterizedTypeReference<T> {
private String separator ; //默认分隔符
private List<String> objects ;//数据
private List<T> list=new ArrayList<>();//数据
private Map<String,String> fieldsTypes = new LinkedHashMap<>();
public CSVToObj(List<String> objects,String separator) {
//特殊符号的处理
this.separator = PatternCommon.division(separator);
this.objects=objects;
}
//列,映射,转换的时候会和映射的顺序保持一致 ,默认使用当前文件的分隔符作为切割
public CSVToObj<T> mapping(String fieldNames){
String[] split = fieldNames.split(separator);
Class<? extends CSVToObj> aClass = ReflectUtil.deSerializable(getClass(),0);
Field[] declaredFields = aClass.getDeclaredFields();
for (String s : split) {
for (Field declaredField : declaredFields) {
declaredField.setAccessible(true);
if(s.equals(declaredField.getName())){
fieldsTypes.put(declaredField.getName(), declaredField.getType().getTypeName());
}
}
}
return this;
}
@SneakyThrows
public CSVToObj<T> transform(){
Class<? extends CSVToObj> aClass = ReflectUtil.deSerializable(getClass(),0);
for (String object : objects) {
String[] split = object.split(separator);
T o = (T)aClass.newInstance();
Field[] declaredFields = o.getClass().getDeclaredFields();
for (int i = 0; i < declaredFields.length; i++) {
Field declaredField = declaredFields[i];
declaredField.setAccessible(true);
if (fieldsTypes.containsKey(declaredField.getName())) {
declaredField.set(o, Converter.cast(split[i],fieldsTypes.get(declaredField.getName())));
}
}
list.add(o);
}
return this;
}
public List<T> result(){
return list;
}
}
package com.file;
import com.entity.UserData;
import com.file.csv.CSVToObj;
import com.file.csv.ReadAndWriteFileCSV;
import com.path.ResourceFileUtil;
import org.junit.Test;
import java.io.File;
import java.util.List;
/**
* csv转对象测试
*
* @Author: huanmin
* @Date: 2022/6/18 16:44
* @Version: 1.0
* @Description: 文件作用详细描述....
*/
public class CSVToObjTest {
@Test
public void show1(){
File absoluteFileOrDirPathAndCreateNewFile = ResourceFileUtil.getAbsoluteFileOrDirPathAndCreateNewFile("/file/text.csv");
//读取头部对应字段
String head = ReadAndWriteFileCSV.readFirstLineOne(absoluteFileOrDirPathAndCreateNewFile);
//去掉头部和尾部的多余信息,只显示内容
List<String> list = ReadAndWriteFileCSV.readSkipHeadAndEnd(absoluteFileOrDirPathAndCreateNewFile);
//做映射,然后转换csv格式为实体对象
List<UserData> result = new CSVToObj<UserData>(list, "|"){}.mapping(head).transform().result();
for (UserData userData : result) {
System.out.println(userData);
}
}
@Test
public void show2(){
File absoluteFileOrDirPathAndCreateNewFile = ResourceFileUtil.getAbsoluteFileOrDirPathAndCreateNewFile("/file/text.csv");
//手动指定文件头部
String head ="id|name|pass|age|sex|site";
//去掉头部和尾部的多余信息,只显示内容
List<String> list = ReadAndWriteFileCSV.readSkipHeadAndEnd(absoluteFileOrDirPathAndCreateNewFile);
List<UserData> result = new CSVToObj<UserData>(list, "|"){}.mapping(head).transform().result();
for (UserData userData : result) {
System.out.println(userData);
}
}
//
}
点赞 -收藏-关注-便于以后复习和收到最新内容有其他问题在评论区讨论-或者私信我-收到会在第一时间回复如有侵权,请私信联系我感谢,配合,希望我的努力对你有帮助^_^
我的一位教授给了我们一些考试练习题,其中一个问题类似于下面(伪代码): a.setColor(blue); b.setColor(red); a = b; b.setColor(purple); b
我似乎经常使用这个测试 if( object && object !== "null" && object !== "undefined" ){ doSomething(); } 在对象上,我
C# Object/object 是值类型还是引用类型? 我检查过它们可以保留引用,但是这个引用不能用于更改对象。 using System; class MyClass { public s
我在通过 AJAX 发送 json 时遇到问题。 var data = [{"name": "Will", "surname": "Smith", "age": "40"},{"name": "Wil
当我尝试访问我的 View 中的对象 {{result}} 时(我从 Express js 服务器发送该对象),它只显示 [object][object]有谁知道如何获取 JSON 格式的值吗? 这是
我有不同类型的数据(可能是字符串、整数......)。这是一个简单的例子: public static void main(String[] args) { before("one"); }
嗨,我是 json 和 javascript 的新手。 我在这个网站找到了使用json数据作为表格的方法。 我很好奇为什么当我尝试使用 json 数据作为表时,我得到 [Object,Object]
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我听别人说 null == object 比 object == null check 例如: void m1(Object obj ) { if(null == obj) // Is thi
Match 对象 提供了对正则表达式匹配的只读属性的访问。 说明 Match 对象只能通过 RegExp 对象的 Execute 方法来创建,该方法实际上返回了 Match 对象的集合。所有的
Class 对象 使用 Class 语句创建的对象。提供了对类的各种事件的访问。 说明 不允许显式地将一个变量声明为 Class 类型。在 VBScript 的上下文中,“类对象”一词指的是用
Folder 对象 提供对文件夹所有属性的访问。 说明 以下代码举例说明如何获得 Folder 对象并查看它的属性: Function ShowDateCreated(f
File 对象 提供对文件的所有属性的访问。 说明 以下代码举例说明如何获得一个 File 对象并查看它的属性: Function ShowDateCreated(fil
Drive 对象 提供对磁盘驱动器或网络共享的属性的访问。 说明 以下代码举例说明如何使用 Drive 对象访问驱动器的属性: Function ShowFreeSpac
FileSystemObject 对象 提供对计算机文件系统的访问。 说明 以下代码举例说明如何使用 FileSystemObject 对象返回一个 TextStream 对象,此对象可以被读
我是 javascript OOP 的新手,我认为这是一个相对基本的问题,但我无法通过搜索网络找到任何帮助。我是否遗漏了什么,或者我只是以错误的方式解决了这个问题? 这是我的示例代码: functio
我可以很容易地创造出很多不同的对象。例如像这样: var myObject = { myFunction: function () { return ""; } };
function Person(fname, lname) { this.fname = fname, this.lname = lname, this.getName = function()
任何人都可以向我解释为什么下面的代码给出 (object, Object) 吗? (console.log(dope) 给出了它应该的内容,但在 JSON.stringify 和 JSON.parse
我正在尝试完成散点图 exercise来自免费代码营。然而,我现在只自己学习了 d3 几个小时,在遵循 lynda.com 的教程后,我一直在尝试确定如何在工具提示中显示特定数据。 This code
我是一名优秀的程序员,十分优秀!