以grails格式呈现CSV格式

时间:2011-03-31 18:01:11

标签: xml json grails csv groovy

Grails提供了Converter类,可以将任何类型的Java / Groovy对象快速转换为XML / JSON响应。 像,

render obj as XML

render obj as JSON

我正在开发一个grails应用程序,它要求我以csv格式呈现对象。有没有办法做到这一点?

我尝试了一些东西,我已经解释了以下内容:

我的代码片段

csv {
    def results = []
    for(d in Data.list()) {
        def r= [d.id, d.name]
        results << r
    }
    def result = ''
    results.each{ row ->
        row.each{
            col -> result += col + ','
        }
        result = result[0..-2]
        result += '\n'
    }
    println result

    render(contentType:'text/csv',text:result)
}

我将结果存储在ArrayList中,然后将它们转换为逗号分隔的字符串,然后将其传递给render方法。当我在浏览器上运行上面的代码时,它会创建所需的文件,浏览器会弹出一个“另存为”文件的对话框。

当我将contentType更改为text / html时,文件内容显示在浏览器上,没有换行符。

是否有更好的方法在浏览器上以与文件相同的方式呈现csv文件的内容。

感谢。

3 个答案:

答案 0 :(得分:3)

您可以将CSV呈现为text/plain而不是text/html。浏览器会将其呈现为纯文本,类似于在编辑器中打开文件时所看到的内容。

答案 1 :(得分:3)

所以我只是想解决同样的问题 - 用CSV下载回复Grails 3请求。

我从Grails slack频道获得了一个提示,使用Apache Commons CSV代码来处理逗号,引号和其他特殊字符等细节。

要使用它,您需要将其添加到项目的依赖项中。在build.gradledependencies下添加:

compile "org.apache.commons:commons-csv:1.2"

这是一个示例控制器,它将所有内容放在一起,并通过域对象Item的CSV下载响应所有请求。

package name.of.package

import grails.rest.*
import grails.converters.*
import org.apache.commons.csv.CSVFormat
import org.apache.commons.csv.CSVPrinter

class ItemController extends RestfulController {

    static responseFormats = ['json', 'xml', 'csv']
    ItemController () {
        super(ApprovedHotel)
    }

    def export(Integer max) {

        def items = Item.list()
        withFormat {
            csv {
                def results = []
                for(d in items) {
                    def r= [d.column1, d.column2]
                    results << r
                }

                StringWriter stringWriter = new StringWriter();
                CSVPrinter printer = new CSVPrinter(stringWriter, CSVFormat.EXCEL);
                printer.printRecords( results )
                printer.flush()
                printer.close()
                result = stringWriter.toString()

                response.setHeader("Content-disposition", "attachment; filename=filename.csv")
                render(contentType:'text/csv',text:result)
            }
        }
    }
}

答案 2 :(得分:2)

如果要在浏览器中显示csv数据,则需要使用

<br>
如果您希望在HTML中正确显示新行,则

而不是\ n表示新行。浏览器通常忽略控制字符,并且只对HTML标记进行基本格式化 如果您想允许用户下载csv文件代码,则以下内容将起作用。

response.setHeader("Content-disposition", "attachment; filename=Edata.csv")
render(contentType: "text/csv", text:varContainingData )