我对scala很新。我试图在scala中使用snakeyaml解析Yaml文件。我正在获取数据,但它是一个对象的形式。我可以转换对象或字符串,但它违背了使用Yaml的全部目的。
e.g。我正在使用的文件是带有数据的“abcd.yaml”
aa:
- x
- y
bb: z
我的代码是这样的:
import java.io.{File, FileInputStream}
import org.yaml.snakeyaml.Yaml
def parseYaml(){
val ios = new FileInputStream(new File("abcd.yaml"))
val yaml = new Yaml()
val obj = yaml.load(ios)
}
但是我在这里得到一个对象,我不能使用里面的值。 任何解决方案?
答案 0 :(得分:3)
我得到了解决方案,它要转换为java地图而不是scala地图:
只需使用asInstanceOf[java.util.Map[String, Any]
,就像魅力一样。
解决方案是像这样调用load:
obj = yaml.load(ios).asInstanceOf[java.util.Map[String, Any]
答案 1 :(得分:0)
为了解压缩单个级别的YAML文件
aa:
- x
- y
bb: z
解决方案是将其转换为您希望在解压缩YAML文件后收到的数据类型,即Map [,],通常最优选的是Map [String,Any]以适应检索到的任何数据类型
val obj = yaml.load(ios).asInstanceOf[java.util.Map[String, Any]]
这是最简单的解决方案,但是,当您在YAML文件中具有多个级别时,此方法将变得难以使用,那么每次您将级别进一步加深时,都必须将新对象强制转换为Map / List。例如YAML文件:
aa:
- x
- y
bb: z
cc:
p: abc
q: 123
r: true
s:
- listItem1
- listItem2
- listItem3
在这种情况下,由于我们在Jackson的JsonNode数据类型中具有灵活性,因此最好依靠SnakeYAML来解析文件并依靠Jackson YAML来遍历文件。
import java.io.{File, FileInputStream, FileReader}
import com.fasterxml.jackson.dataformat.yaml.YAMLFactory
import com.fasterxml.jackson.module.scala.DefaultScalaModule
import com.fasterxml.jackson.databind.{JsonNode, ObjectMapper}
import org.yaml.snakeyaml.Yaml
// Parsing the YAML file with SnakeYAML - since Jackson Parser does not have Anchors and reference support
val ios = new FileInputStream(new File(yamlFilePath))
val yaml = new Yaml()
val mapper = new ObjectMapper().registerModules(DefaultScalaModule)
val yamlObj = yaml.loadAs(ios, classOf[Any])
// Converting the YAML to Jackson YAML - since it has more flexibility
val jsonString = mapper.writerWithDefaultPrettyPrinter().writeValueAsString(yamlObj) // Formats YAML to a pretty printed JSON string - easy to read
val jsonObj = mapper.readTree(jsonString)
JsonNode可以使用JsonNode的at或get方法进行解析:
jsonObj.at("/cc/r").asBoolean // Returns boolean of value in r
jsonObj.get("bb") // Returns the value in key bb
利用JsonNode中的asText,asBoolean,asInt等方法将简化数据提取和类型转换过程