2012-07-26 4 views
13

ho un JSON come il seguente:JSON.NET come rimuovere i nodi

{ 
    "d": { 
    "results": [ 
     { 
     "__metadata": { 
     }, 
     "prop1": "value1", 
     "prop2": "value2", 
     "__some": "value" 
     }, 
     { 
     "__metadata": { 
     }, 
     "prop3": "value1", 
     "prop4": "value2", 
     "__some": "value" 
     }, 
    ] 
    } 
} 

Voglio solo di trasformare questo in un JSON JSON diverso. Voglio rimuovere i "_ metadata" e " _some" nodi da JSON. Sto usando JSON.NET.

+1

Non ho esperienza con C# ma presumo che tu possa semplicemente analizzare il JSON, eliminare le chiavi dalla struttura dei dati risultanti e convertirle nuovamente in JSON. –

+0

Posso farlo, ma stavo cercando JSON.NET modo di farlo. –

risposta

25

Ho appena finito di deserializzare in JObject e ricorsivamente in looping per rimuovere i campi indesiderati. Ecco la funzione per chi è interessato.

private void removeFields(JToken token, string[] fields) 
{ 
    JContainer container = token as JContainer; 
    if (container == null) return; 

    List<JToken> removeList = new List<JToken>(); 
    foreach (JToken el in container.Children()) 
    { 
     JProperty p = el as JProperty; 
     if (p != null && fields.Contains(p.Name)) 
     { 
      removeList.Add(el); 
     } 
     removeFields(el, fields); 
    } 

    foreach (JToken el in removeList) 
    { 
     el.Remove(); 
    } 
} 
+0

Grazie! Ne avevo bisogno. Ora posso fare un Foreach sulla mia collezione di JArray's Children per rimuovere tutte le mie proprietà che voglio. – duyn9uyen

+0

Questo mi ha davvero aiutato: volevo registrare i dati JSON con campi sensibili sostituiti dalla lunghezza dei dati. Sono stato in grado di ottenere e impostare p.Valore. – 79IT

2

Vorrei creare una nuova struttura dati con solo le informazioni richieste e copiare i dati dal primo. Spesso questo è l'approccio più semplice. Solo un'idea

+1

Ma non so quali saranno i dati. Voglio scrivere una funzione generica che utilizzi una stringa JSON e un elenco di proprietà da escludere (forse il tipo xpath?) E restituisce una nuova stringa JSON senza le proprietà escluse. –

9

Costruzione off di @ [Mohamed Nuur] 's risposta, ho cambiato in un metodo di estensione che credo lavori meglio:

public static JToken RemoveFields(this JToken token, string[] fields) 
    { 
     JContainer container = token as JContainer; 
     if (container == null) return token; 

     List<JToken> removeList = new List<JToken>(); 
     foreach (JToken el in container.Children()) 
     { 
      JProperty p = el as JProperty; 
      if (p != null && fields.Contains(p.Name)) 
      { 
       removeList.Add(el); 
      } 
      el.RemoveFields(fields); 
     } 

     foreach (JToken el in removeList) 
     { 
      el.Remove(); 
     } 

     return token; 
    } 

Ecco unit test:

[TestMethod] 
    public void can_remove_json_field_removeFields() 
    { 
     string original = "{\"d\":{\"results\":[{\"__metadata\":{},\"remove\":\"done\",\"prop1\":\"value1\",\"prop2\":\"value2\",\"__some\":\"value\"},{\"__metadata\":{},\"prop3\":\"value1\",\"prop4\":\"value2\",\"__some\":\"value\"}],\"__metadata\":{\"prop3\":\"value1\",\"prop4\":\"value2\"}}}"; 
     string expected = "{\"d\":{\"results\":[{\"prop1\":\"value1\",\"prop2\":\"value2\",\"__some\":\"value\"},{\"prop3\":\"value1\",\"prop4\":\"value2\",\"__some\":\"value\"}]}}"; 
     string actual = JToken.Parse(original).RemoveFields(new string[]{"__metadata", "remove"}).ToString(Newtonsoft.Json.Formatting.None); 
     Assert.AreEqual(expected, actual); 
    }