Próbuję przekonwertować obiekt hashtable na obiekt json, aby mógł być używany w serwisie WWW z programem powershell 2.0.Jak mogę przekonwertować przyspieszony na ciąg json w powershell?
$testhash = @{
Name = 'John Doe'
Age = 10
Amount = 10.1
MixedItems = (1,2,3,"a")
NestedHash = @{
nestedkey = "nextedvalue"
}
}
function toJson($obj){
$ms = New-Object IO.MemoryStream
$type = $obj.getType()
[Type[]]$types = ($obj | select -expand PsTypeNames | Select -unique) + [type]'System.Management.Automation.PSObject'
$js = New-Object System.Runtime.Serialization.Json.DataContractJsonSerializer $type, $types, ([int]::MaxValue), $false, $null, $false
$js.writeObject($ms, $obj) | out-null
$utf8.GetString($ms.ToArray(), 0, $ms.Length)
$ms.Dispose() | out-null
}
toJson $testhash
'[{"Key":"Name","Value":"John Doe"},{"Key":"Age","Value":10},{"Key":"Amount","Value":10.1},{"Key":"NestedHash","Value":[{"__type":"KeyValuePairOfanyTypeanyType:#System.Collections.Generic","key":"nestedkey","value":"nextedvalue"}]},{"Key":"MixedItems","Value":[1,2,3,"a"]}]'
Używam DataContractJsonSerializer constructor w sposób, który powinien tłumić informacje o typie, ale to nie jest oczywisty. Jestem również rozbawiony tym, że wyodrębnia pary kluczy i wartości, ale chciałbym, aby tak się nie stało. Co ja robię źle?
To wydaje się czymś funkcja serialize powinien zrobić na swój własny, nie? Tak czy inaczej - działa to prawie idealnie - kończy się niepowodzeniem na dwóch poziomach zagnieżdżonych skrótów. – reconbot
@wizard - Przypuszczam, że powinienem używać prostych tabliczek. Możesz wyglądać aroudn, istnieją już skrypty takie jak ja połączone z robieniem parsowania JSON. – manojlds
Skończyło się na tym, że http://poshcode.org/2930 ma problemy, ale działa wystarczająco dobrze - jeden dzień będzie dostępny w wersji Power Shell 3.0, a ja spojrzę wstecz na te zmarnowane godziny i będę zdenerwowany. – reconbot