一、文档类型简介

1、XML文档

XML是可扩展标记语言,是一种用于标记电子文件使其具有结构性的标记语言。标记指计算机所能理解的信息符号,通过此种标记,计算机之间可以处理包含各种的信息比如数据结构,格式等。它可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。适合网络传输,提供统一的方法来描述和交换应用程序的结构化数据。

2、CSV文档

CSV文档,以逗号分隔文档内容值,其文件以纯文本形式存储结构数据。CSV文件由任意数目的记录组成,记录间以某种换行符分隔;每条记录由字段组成,字段间的分隔符是其它字符或字符串,最常见的是逗号。CSV是一种通用的、相对简单的文件格式,通常被用在大数据领域,进行大规模的数据搬运操作。

二、XML文件管理

1、Dom4j依赖

Dom4j是基于Java编写的XML文件操作的API包,用来读写XML文件。具有性能优异、功能强大和简单易使用的特点。

dom4j    dom4j    1.6.1jaxen    jaxen    1.1.6

2、基于API封装方法

涉及对XML文件读取、加载、遍历、创建、修改、删除等常用方法。

public class XmlUtil {    /**     * 创建文档     */    public static Document getDocument (String filename) {        File xmlFile = new File(filename) ;        Document document = null;        if (xmlFile.exists()){            try{                SAXReader saxReader = new SAXReader();                document = saxReader.read(xmlFile);            } catch (Exception e){                e.printStackTrace();            }        }        return document ;    }    /**     * 遍历根节点     */    public static Document iteratorNode (String filename) {        Document document = getDocument(filename) ;        if (document != null) {            Element root = document.getRootElement();            Iterator iterator = root.elementIterator() ;            while (iterator.hasNext()) {                Element element = (Element) iterator.next();                System.out.println(element.getName());            }        }        return document ;    }    /**     * 创建XML文档     */    public static void createXML (String filePath) throws Exception {        // 创建 Document 对象        Document document = DocumentHelper.createDocument();        // 创建节点,首个节点默认为根节点        Element rootElement = document.addElement("project");        Element parentElement = rootElement.addElement("parent");        parentElement.addComment("版本描述") ;        Element groupIdElement = parentElement.addElement("groupId") ;        Element artifactIdElement = parentElement.addElement("artifactId") ;        Element versionElement = parentElement.addElement("version") ;        groupIdElement.setText("SpringBoot2");        artifactIdElement.setText("spring-boot-starters");        versionElement.setText("2.1.3.RELEASE");        //设置输出编码        OutputFormat format = OutputFormat.createPrettyPrint();        File xmlFile = new File(filePath);        format.setEncoding("UTF-8");        XMLWriter writer = new XMLWriter(new FileOutputStream(xmlFile),format);        writer.write(document);        writer.close();    }    /**     * 更新节点     */    public static void updateXML (String filePath) throws Exception {        Document document = getDocument (filePath) ;        if (document != null){            // 修改指定节点            List elementList = document.selectNodes("/project/parent/groupId");            Iterator iterator = elementList.iterator() ;            while (iterator.hasNext()){                Element element = (Element) iterator.next() ;                element.setText("spring-boot-2");            }            //设置输出编码            OutputFormat format = OutputFormat.createPrettyPrint();            File xmlFile = new File(filePath);            format.setEncoding("UTF-8");            XMLWriter writer = new XMLWriter(new FileOutputStream(xmlFile),format);            writer.write(document);            writer.close();        }    }    /**     * 删除节点     */    public static void removeElement (String filePath) throws Exception {        Document document = getDocument (filePath) ;        if (document != null){            // 修改指定节点            List elementList = document.selectNodes("/project/parent");            Iterator iterator = elementList.iterator() ;            while (iterator.hasNext()){                Element parentElement = (Element) iterator.next() ;                Iterator parentIterator = parentElement.elementIterator() ;                while (parentIterator.hasNext()){                    Element childElement = (Element)parentIterator.next() ;                    if (childElement.getName().equals("version")) {                        parentElement.remove(childElement) ;                    }                }            }            //设置输出编码            OutputFormat format = OutputFormat.createPrettyPrint();            File xmlFile = new File(filePath);            format.setEncoding("UTF-8");            XMLWriter writer = new XMLWriter(new FileOutputStream(xmlFile),format);            writer.write(document);            writer.close();        }    }    public static void main(String[] args) throws Exception {        String filePath = "F:file-typeproject-cf.xml" ;        // 1、创建文档        Document document = getDocument(filePath) ;        System.out.println(document.getRootElement().getName());        // 2、根节点遍历        iteratorNode(filePath);        // 3、创建XML文件        String newFile = "F:file-typeproject-cf-new.xml" ;        createXML(newFile) ;        // 4、更新XML文件        updateXML(newFile) ;        // 5、删除节点        removeElement(newFile) ;    }}

3、执行效果图

三、CSV文件管理

1、CSV文件样式

这里不需要依赖特定的Jar包,按照普通的文件读取即可。

2、文件读取

@Async@Overridepublic void readNotify(String path, Integer columnSize) throws Exception {    File file = new File(path) ;    String fileName = file.getName() ;    int lineNum = 0 ;    if (fileName.startsWith("data-")) {        InputStreamReader isr = new InputStreamReader(new FileInputStream(file),"GBK") ;        BufferedReader reader = new BufferedReader(isr);        List dataInfoList = new ArrayList<>(4);        String line  ;        while ((line = reader.readLine()) != null) {            lineNum ++ ;            String[] dataArray = line.split(",");            if (dataArray.length == columnSize) {                String cityName = new String(dataArray[1].getBytes(),"UTF-8") ;                dataInfoList.add(new DataInfo(Integer.parseInt(dataArray[0]),cityName,dataArray[2])) ;            }            if (dataInfoList.size() >= 4){                LOGGER.info("容器数据:"+dataInfoList);                dataInfoList.clear();            }        }        if (dataInfoList.size()>0){            LOGGER.info("最后数据:"+dataInfoList);        }        reader.close();    }    LOGGER.info("读取数据条数:"+lineNum);}

3、文件创建

@Async@Overridepublic void createCsv(List dataList,String path) throws Exception {    File file = new File(path) ;    boolean createFile = false ;    if (file.exists()){        boolean deleteFile = file.delete() ;        LOGGER.info("deleteFile:"+deleteFile);    }    createFile = file.createNewFile() ;    OutputStreamWriter ost = new OutputStreamWriter(new FileOutputStream(path),"UTF-8") ;    BufferedWriter out = new BufferedWriter(ost);    if (createFile){        for (String line:dataList){            if (!StringUtils.isEmpty(line)){                out.write(line);                out.newLine();            }        }    }    out.close();}

4、编写测试接口

这里基于Swagger2管理接口测试 。

@Api("Csv接口管理")@RestControllerpublic class CsvWeb {    @Resource    private CsvService csvService ;    @ApiOperation(value="文件读取")    @GetMapping("/csv/readNotify")    public String readNotify (@RequestParam("path") String path,                              @RequestParam("column") Integer columnSize) throws Exception {        csvService.readNotify(path,columnSize);        return "success" ;    }    @ApiOperation(value="创建文件")    @GetMapping("/csv/createCsv")    public String createCsv (@RequestParam("path") String path) throws Exception {        List dataList = new ArrayList<>() ;        dataList.add("1,北京,beijing") ;        dataList.add("2,上海,shanghai") ;        dataList.add("3,苏州,suzhou") ;        csvService.createCsv(dataList,path);        return "success" ;    }}

文中涉及文件类型,在该章节源码ware18-file-parent/case-file-type目录下。


推荐阅读:GitHub源码和分类管理,持续更新

文件系统(01):基于SpringBoot管理Excel和PDF

SpringBoot2 整合 Drools规则引擎,实现高效的业务规则

SpringBoot2 整合MinIO中间件,实现文件便捷管理

SpringBoot2.0 整合 Shiro 框架,实现用户权限管理

SpringBoot2 整合 ClickHouse数据库,实现高性能数据查询分析

SpringBoot2 整合FreeMarker模板,完成页面静态化处理

SpringBoot2 整合JTA组件,多数据源事务管理

SpringBoot2 整合Ehcache组件,轻量级缓存管理

SpringBoot2 整合Kafka组件,应用案例和流程详解

SpringBoot2 集成日志,复杂业务下的自定义实现

csv逗号分隔符转换_文件系统(02):基于SpringBoot管理Xml和CSV相关推荐

  1. csv逗号分隔符转换_机器学习Python实践——数据导入(CSV)

    一,CSV 逗号分隔值(逗号分隔值,CSV,有时也称为字符分隔值,因为分隔字符也可以不是逗号),其文件以纯文本形式存储表格数据(数字和文本).字幕:纯意味着该文件的英文一个字符序列,不含必须像二进制数 ...

  2. csv逗号分隔符转换_CSV文件存储

    CSV ,全称为 Comma-Separated Values ,中文可以叫逗号分隔值或字符分隔值,其文件以纯文本形式存储表格数据.该文件是一个字符序列,可以由任意数目的记录组成,记录间以某种换行符分 ...

  3. csv逗号分隔符转换_Pandas中处理Csv和Excel数据详解

    作者:Zarten知乎专栏:python数据分析与挖掘深入详解知乎ID: Zarten简介: 互联网一线工作者,尊重原创并欢迎评论留言指出不足之处,也希望多些关注和点赞是给作者最好的鼓励 ! 概述 通 ...

  4. csv逗号分隔符转换_pythonpandas读写csv数据

    官方介绍: pandas的官方手册: https://pandas.pydata.org/pandas-docs/stable/ pandas官方读写数据文档: https://pandas.pyda ...

  5. boot spring 解析csv_文件系统(02):基于SpringBoot框架,管理Xml和CSV文件类型-阿里云开发者社区...

    一.文档类型简介 1.XML文档 XML是可扩展标记语言,是一种用于标记电子文件使其具有结构性的标记语言.标记指计算机所能理解的信息符号,通过此种标记,计算机之间可以处理包含各种的信息比如数据结构,格 ...

  6. 文件系统(02):基于SpringBoot框架,管理Xml和CSV文件类型

    本文源码:GitHub·点这里 || GitEE·点这里 一.文档类型简介 1.XML文档 XML是可扩展标记语言,是一种用于标记电子文件使其具有结构性的标记语言.标记指计算机所能理解的信息符号,通过 ...

  7. springboot md5加密_实在!基于Springboot和WebScoket,写了一个在线聊天小程序

    基于Springboot和WebScoket写的一个在线聊天小程序 (好几天没有写东西了,也没有去练手了,就看了看这个...) 项目说明 此项目为一个聊天的小demo,采用springboot+web ...

  8. springboot增删改查案例_大神基于SpringBoot开发一个Restful服务,实现增删改查功能...

    前言 在去年的时候,在各种渠道中略微的了解了SpringBoot,在开发web项目的时候是如何的方便.快捷.但是当时并没有认真的去学习下,毕竟感觉自己在Struts和SpringMVC都用得不太熟练. ...

  9. python 文件格式转换_数据分析:基于Python的自定义文件格式转换系统

    ( 白宁超 2018年7月16日14:47:41 ) 导读:随着大数据的快速发展,自然语言处理.数据挖掘.机器学习技术应用愈加广泛.针对大数据的预处理工作是一项庞杂.棘手的工作.首先数据采集和存储,尤 ...

  10. python写csv文件分隔符问题_导出csv文件时,处理分隔符问题(转)

    CSV文件默认以英文逗号做为列分隔符,换行符作为行分隔符. 如果不提供网页形式只用命令行或二进制程序输出数据到CSV,只需要将数据段按,分割,行按\n分割,写入到一个.csv文件即可. 但有时字段里含 ...

最新文章

  1. PYTHON编程导论群问题汇总(二)
  2. Linux 学习和教训
  3. vb6编写dll读取dat文件_【STM32Cube_15】使用硬件I2C读取温湿度传感器数据(SHT30)...
  4. linux内核那些事之VMA常用操作
  5. javamail 超时_为什么JavaMail连接超时太长
  6. CLR via C# 内存管理读书记
  7. css权威指南笔记,《CSS权威指南》读书笔记(1)
  8. ACM算法设计---BFS、DFS
  9. 十年里程碑 vivo X80铸造高端手机的主色调
  10. 大学物理复习5-角动量定理+角动量守恒定律
  11. HashSet模拟新浪微博用户注册
  12. 山东理工ACM 1151 C语言实验——输出字符串
  13. 未来计算机专业会怎么样
  14. 2020年12月计算机一级考试,5省市已公布2020年12月计算机等级考试时间,切勿错过!...
  15. 域控服务器组策略管理找不到网络,组策略找不到域服务器解决方法重建SYSVOL和NETLOGON共享...
  16. 远离喧嚣,拥抱自然,洗尽铅华
  17. Python数据结构04-冒泡、选择、插入、归并、希尔、快速排序、二分查找
  18. 单链表实现一元多项式相加
  19. 高校动态|北大“韦神”获达摩院青橙奖,奖金100万元!一同获奖的还有他们!
  20. 柯尼卡美能达Konica Minolta bizhub C7122 打印机驱动

热门文章

  1. 【TSP】基于matlab GUI遗传算法求解旅行商问题【含Matlab源码 1333期】
  2. 【语音识别】基于matlab特定人的语音识别分辨【含Matlab源码 534期】
  3. 【图像边缘检测】基于matlab GUI Sobel+Prewitt+Robert算子图像边缘检测【含Matlab源码 203期】
  4. oracle 表或视图不存在_sqlalchemy反射不存在主键的表引发的问题
  5. web与ai相结合成为趋势_将AI和行为科学相结合可以改变体验
  6. android 结算权限,如何在Android应用程序中实施应用内结算?
  7. 例2.6 Sort - 九度教程第11题(Hash的应用)
  8. 腾讯体育php面试题,腾讯php程序员面试题目及答案分享!
  9. linux怎么重载mysql配置命令_【Linux命令】数据库mysql配置命令
  10. vue-cli mock