如何解决groovy从csv转换为json
如何将CSV转换为JSON并单独访问对象以创建自定义字符串?在以下代码中,为什么我无法查看log.info(rows.Id [0])的输出?当我打印时,在控制台中显示为空。
data.csv具有两列(ID,值),其中包含100行。
import groovy.json.JsonOutput
import groovy.json.JsonSlurper
def lines = new File('data.csv').readLines()
def keys = lines[0].split(',')
def rows = lines[1..-1].collect { line ->
def i = 0,vals = line.split(',')
keys.inject([:]) { map,key -> map << ["$key": vals[i++]] }
}
def jsonSlurper = new JsonSlurper()
jsonSlurper = jsonSlurper.parse(JsonOutput.toJson(rows))
log.info(JsonOutput.prettyPrint(JsonOutput.toJson(rows)))
log.info(rows.Id[0])
解决方法
您的问题是在地图中使用GString作为键。这个 看起来/打印起来像一个字符串键,但是在身份方面(地图的方式 查找事物)不是。
groovy:000> key = "a"
===> a
groovy:000> ["$key": 1].containsKey(key)
===> false
groovy:000> [(key): 1].containsKey(key)
===> true
因此,请使用:[(key): vals[i++]]
。
或者,如果您想进一步打高尔夫球:
[keys,line.split(',')].transpose().collectEntries()
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。