我从第三方收到了一个json,当反序列化时它有一个动态对象列表,格式如下
period key value
"2013-3" 0 5
"2013-4" 1 6
.
.
.
"2013-10" 5 15
"2013-11" mykey1 25
"2013-12" mykey3 6在这方面,当我试图运行一个linq查询时,我会得到一个错误。System.FormatException:输入字符串格式不正确。
如果我只保留键列中的字符串或int值,这种情况就会消失。
任何帮助都是真诚的感谢。
示例linq查询::
data.Where(w => w.key == "mykey1").Select(s => s.value).ToArray();示例:http://rextester.com/OMRG78541
发布于 2016-12-25 14:34:42
由于使用的是动态对象,因此需要强制转换键以验证lambda表达式中的谓词。这是因为即使您使用的是动态的,底层对象是一个JValue,它不允许字符串和JValue之间的==
data.Where(w => (string)w.key == "mykey1").Select(s => s.value).ToArray(); 给定示例代码
namespace Rextester
{
public class Program
{
public static void Main(string[] args)
{
var json = "[{\"period\":\"2013-3\",\"key\":1,\"val\":18148},{\"period\":\"2013-3\",\"key\":\"totalinteractions\",\"val\":95862},{\"period\":\"2013-3\",\"key\":\"totalusers\",\"val\":160389},{\"period\":\"2013-4\",\"key\":\">10\",\"val\":69915}]";
var inputdata = JsonConvert.DeserializeObject<IEnumerable<dynamic>>(json);
var list = inputdata.Where(w => (string)w.key == "totalusers").Select(s => s.val).ToArray();
foreach (var item in list)
{
Console.WriteLine(item);
}
}
}
}以上的输出将导致
160389https://stackoverflow.com/questions/41321593
复制相似问题