2015-10-25 111 views
0

我必須提取JSON響應的信息並評估是否有某個文件存在或不存在。我用下面的方法定義:模式匹配中的Scala擦除

override def hasField(field: Field): Boolean = { 
    val schema = parse(httpClient.doGet(url + Solr5EndpointUris.schemaOverviewEndpoint)).extract[Map[String, Any]] 

    val fieldsNames: List[String] = schema.get("schema") match { 
    case schema: Some[Map[String, Any]] => schema.get(if (field.dynamic) "dynamicFields" else "fields") match { 
     case fields: List[Map[String, Any]] => fields.map { 
     case field: Map[String, Any] => field.get("name") match { 
      case name: Some[String] => name.getOrElse("") 
     } 
     } 
     case _ => throw new ApiException("Malformed Response! Missing definition for schema > fields/dynamicFields.") 
    } 
    case _ => throw new ApiException("Malformed Response! Could not extract schema from JSON.") 
    } 

    fieldsNames.contains(field.name) 
} 

的方法檢查通過模式匹配的JSON響應,如果有特定名稱的字段存在應返回true。一個例子JSON響應可能是以下幾點:

{ 
    "responseHeader":{ 
    "status":0, 
    "QTime":2}, 
    "schema":{ 
    "name":"example-data-driven-schema", 
    "version":1.5, 
    "uniqueKey":"id", 
    "fieldTypes":[], 
    "fields":[{ 
     "name":"id", 
     "type":"string", 
     "multiValued":false, 
     "indexed":true, 
     "required":true, 
     "stored":true}], 
    "dynamicFields":[], 
    "copyFields":[] 
    } 
} 

此實現的工作,但我敢肯定有一個更直接的/不那麼複雜的實現來實現這一目標。我還得到很多類似於以下的警告:

SchemaManager.scala:38:類型模式中的非變量類型參數Map [String,Any]某些[Map [String,Any]]未被選中,因爲它被消除通過刪除

任何人都可以提供更好的解決方案,和/或解釋我得到的警告?

回答

1
SchemaManager.scala:38: non-variable type argument Map[String,Any] in type pattern Some[Map[String,Any]] is unchecked since it is eliminated by erasure 

斯卡拉編譯器會刪除編譯時泛型類型。所以當你使用pattern match時,編譯器會擦除你的匹配類型參數。並拋出這個警告。它調用類型擦除

對於你的問題,你可以使用json4sJSON提取物:

scala> import org.json4s._ 
scala> import org.json4s.native.JsonMethods._ 
scala> val jsonStr = "{\n \"responseHeader\":{\n \"status\":0,\n \"QTime\":2},\n \"schema\":{\n \"name\":\"example-data-driven-schema\",\n \"version\":1.5,\n \"uniqueKey\":\"id\",\n \"fieldTypes\":[],\n \"fields\":[{\n  \"name\":\"id\",\n  \"type\":\"string\",\n  \"multiValued\":false,\n  \"indexed\":true,\n  \"required\":true,\n  \"stored\":true}],\n \"dynamicFields\":[],\n \"copyFields\":[]\n }\n}" 
scala> implicit val formats = DefaultFormats 
scala> val f = parse(jsonStr) 
scala> println((f \\ "schema" \\ "fields" \\ "name").extractOrElse("Null")) 
id 
scala> println((f \\ "schema" \\ "fields" \\ "unknow").extractOrElse("Null")) 
Null 

使用extractOrElse設置默認值。