gpt4 book ai didi

xml - 在 grails 中以 CSV 格式呈现

转载 作者:数据小太阳 更新时间:2023-10-29 02:02:33 24 4
gpt4 key购买 nike

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

render obj as XML

render obj as JSON

我正在开发一个要求我以 csv 格式呈现对象的 grails 应用程序。有办法吗?

我尝试了一些东西,并在下面做了解释:

我的代码片段

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 中,然后将它们转换为逗号分隔的字符串,然后将其传递给渲染方法。当我在浏览器上运行上面的代码时,它会创建所需的文件,浏览器会弹出一个对话框以将文件“另存为”。

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

有没有更好的方法在浏览器上呈现 csv 文件的内容,就像在文件上一样。

谢谢。

最佳答案

所以我只是想解决同样的问题——用 CSV 下载响应 Grails 3 请求。

我从 Grails slack channel 得到了使用 Apache Commons CSV 代码的提示,它负责处理逗号、引号和其他特殊字符等细节。

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

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

这是一个示例 Controller ,它将所有内容放在一起并使用域对象 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)
}
}
}
}

关于xml - 在 grails 中以 CSV 格式呈现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5504246/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com