zoukankan      html  css  js  c++  java
  • Create a CSV file

    Create a CSV file | Groovy Examples

    Create a CSV file

    For this example, let’s assume we have an array of maps as our data.

    def planets = [
        [id:'1',color:'red',planet:'mars',description:'Mars, the "red" planet'],
        [id:'2',color:'green',planet:'neptune',description:'Neptune, the "green" planet'],
        [id:'3',color:'blue',planet:'earth',description:'Earth, the "blue" planet'],
    ]

    Next, we can create our CSV file as follows:

    def out = new File('planets.csv')
    planets.each {
        def row = [it.id, it.color, it.planet]
        out.append row.join(',')
        out.append '\n'
    }

    Which creates a file with the following content:

    1,red,mars
    2,green,neptune
    3,blue,earth
    

    However, this does not contain our description field. If you need to also handle double quotes and commas in your data then you can:

    1. qualify your values with a double quote, and
    2. replace double quotes in your data with an escaped double quote.

    In this case our code may look like:

    def out = new File('planets.csv')
    planets.each {
        def row = [it.id, it.color, it.planet, it.description]
                            .collect { '"' + it.replace('"','""') + '"' }
        out.append row.join(',')
        out.append '\n'
    }

    Which creates a file with the following content:

    "1","red","mars","Mars, the ""red"" planet"
    "2","green","neptune","Neptune, the ""blue"" planet"
    "3","blue","earth","Earth, the ""blue"" planet"
  • 相关阅读:
    LVM 扩容硬盘笔记
    jupyter notebook 远程访问
    samba 配置文件详解
    linux 网络挂载 windows 共享文件夹
    cmder 与 win10 wsl ( 当前目录打开wsl)
    vscode for latex
    Python 使用代理
    Python Signal(信号) 异步系统事件
    centos7 install magento
    lua笔记
  • 原文地址:https://www.cnblogs.com/lexus/p/2588576.html
Copyright © 2011-2022 走看看