Java解析CSV文件并导出数据
Java解析CSV文件并导出筛选过得数据
pom.xml引入jar包
<!--csv--> <dependency> <groupId>com.opencsv</groupId> <artifactId>opencsv</artifactId> <version>4.4</version> </dependency>
使用IO流解析,转化数组形式
/** * <b>将csv文件通过IO流解析,转化数组形式的集合<b> * * @param fileName 文件(路径+csv文件名) */ public static List<String[]> csv(String fileName) { List<String[]> csvList = new ArrayList<String[]>(); if (null != fileName) { try { InputStreamReader is = new InputStreamReader(new FileInputStream(fileName),"gbk"); CSVParser csvParser = new CSVParserBuilder().build(); CSVReader reader = new CSVReaderBuilder(is).withCSVParser(csvParser).build(); csvList = reader.readAll(); }catch (UnsupportedEncodingException e){ e.printStackTrace(); }catch (IOException e) { e.printStackTrace(); } } return csvList; }
测试并解析需要的数据并导出到对应文件
public static void main(String[] args) throws IOException { // 读取的csv文件 List<String[]> csv = csv("F:/interCode/interCode.csv"); // 保存数据的文件 File file = new File("F:/interCode/interCode.txt"); if (file.exists()) { file.mkdirs(); } FileOutputStream outputStream = null; for (String[] strings : csv) { String trim = strings[0].trim(); // 业务处理逻辑 String s = encodeBase(trim); if (!s.equals("传递参数不完整!")) { outputStream = new FileOutputStream(file,true); byte[] bytes = s.getBytes(); // 写入数据 outputStream.write(bytes); // 换行 outputStream.write("\r\n".getBytes()); } } System.out.println("执行结束!"); // 关闭流 outputStream.close(); }
此处不做过多描述,C+V即用,根据自行情况稍加改动即可,代码中都有相关注释
无论风雨,和自己一决胜负吧
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律