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()

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...