2012-01-18 91 views
2

首先,为了让所有人都对此感兴趣: 我有一个我需要查询各种数据点的API(CrunchBase)使用此工具为它生成类http://json2csharp.com/#(返回需要与该JSON URL进行交互的类)接下来,我需要使用该服务,输入Scott Hanselman进行救援,使用他的博客文章了解如何执行此操作http://www.hanselman.com/blog/NuGetPackageOfTheWeek4DeserializingJSONWithJsonNET.aspx接下来我将两人在一起,并做了一些修补以允许我查询部分所需信息的CrunchBase API。目前我只是用控制台应用程序来制定逻辑,因为我打算稍后将其包装在.dll中,以用于向MVC网站提供信息的DataModel项目的DAL层。在JSON API调用中循环访问列表<Objects>(CrunchBase)

问题:目前为止,除了我不知道我应该怎么做才能遍历从JSON端点返回的子对象。我的代码发布给任何想看到实现的人(我在网上找不到任何用于在C#中调用CrunchBase API的示例)此代码在我知道需要某些有点foreach循环的位置发表评论但我发现的所有例子都不适合我。任何方向如何做到这一点非常感谢。一个例子或者一个代码纠正对于帮助我自己和其他人自己解决其他问题将会有很大的帮助。另外的问题,这可以全部在C#中完成,或者我需要使用别的东西 - 如果有的话,你可以推荐额外的后续研究?

此代码中使用的端点是“http://api.crunchbase.com/v/1/company/”+ CompanyName +“。js”非常感谢您的提前,我试了很久, 。

.... 
using System.Net; 
using Newtonsoft.Json; 

namespace CrunchBase 
{ 
    class Program 
    { 
     static void Main(string[] args) 
     { 
      Console.WriteLine("Enter the name of a Company to look up:"); 
      string CompanyName = Console.ReadLine(); 

      var client = new WebClient(); 
      client.Headers.Add("User-Agent", "Nobody"); //my endpoint needs this... 
      var response = client.DownloadString(new Uri("http://api.crunchbase.com/v/1/company/" + CompanyName +".js")); 

      var j = JsonConvert.DeserializeObject<RootObject>(response); 
      var f = JsonConvert.DeserializeObject<FundingRound>(response); 
      var i = JsonConvert.DeserializeObject<Investment>(response); 

       Console.WriteLine("Company Name: {0}", j.name); 
       Console.WriteLine("Web Page: {0}", j.homepage_url); 
       Console.WriteLine("Email Adress: {0}", j.email_address); 
       Console.WriteLine("CruchBase Page: {0}", j.crunchbase_url); 
       Console.WriteLine("Category: {0}", j.category_code); 
       Console.WriteLine("Description: {0}", j.description); 
       Console.WriteLine("Number of Employees: {0}", j.number_of_employees); 
       Console.WriteLine("Year Founded: {0}", j.founded_year); 
       // How would the best aproach be to loop through all of the Objects and print their properties? 
       // By the way, if you run this it will hang a little bit because the FundingRound object is not 
       // properly implemented at the moment. 
       Console.WriteLine("Funding Round Type: {0}", f.round_code); 
       Console.WriteLine("Information Source: {0}", f.source_url); 
       Console.WriteLine("Description: {0}", f.source_description); 
       Console.WriteLine("Raised Amount: {0} {1}", f.raised_currency_code, f.raised_amount); 
       // I take it the same technique used to loop through the above "f" var object 
       // I would use again to loop through to the next nested Investment object 
       // and on down the chain fefore returning right back up.... 

       Console.ReadLine(); 
     } 

     public class Image 
     { 
      public List<List<object>> available_sizes { get; set; } 
      public object attribution { get; set; } 
     } 

     public class Person 
     { 
      public string first_name { get; set; } 
      public string last_name { get; set; } 
      public string permalink { get; set; } 
     } 

     public class Relationship 
     { 
      public bool is_past { get; set; } 
      public string title { get; set; } 
      public Person person { get; set; } 
     } 

     public class Provider 
     { 
      public string name { get; set; } 
      public string permalink { get; set; } 
     } 

     public class Providership 
     { 
      public string title { get; set; } 
      public bool is_past { get; set; } 
      public Provider provider { get; set; } 
     } 

     public class FinancialOrg 
     { 
      public string name { get; set; } 
      public string permalink { get; set; } 
     } 

     public class Person2 
     { 
      public string first_name { get; set; } 
      public string last_name { get; set; } 
      public string permalink { get; set; } 
     } 

     public class Investment 
     { 
      public object company { get; set; } 
      public FinancialOrg financial_org { get; set; } 
      public Person2 person { get; set; } 
     } 

     public class FundingRound 
     { 
      public string round_code { get; set; } 
      public string source_url { get; set; } 
      public string source_description { get; set; } 
      public double raised_amount { get; set; } 
      public string raised_currency_code { get; set; } 
      public int funded_year { get; set; } 
      public int funded_month { get; set; } 
      public int funded_day { get; set; } 
      public List<Investment> investments { get; set; } 
     } 

     public class Office 
     { 
      public string description { get; set; } 
      public string address1 { get; set; } 
      public string address2 { get; set; } 
      public string zip_code { get; set; } 
      public string city { get; set; } 
      public string state_code { get; set; } 
      public string country_code { get; set; } 
      public object latitude { get; set; } 
      public object longitude { get; set; } 
     } 

     public class VideoEmbed 
     { 
      public string embed_code { get; set; } 
      public string description { get; set; } 
     } 

     public class Screenshot 
     { 
      public List<List<object>> available_sizes { get; set; } 
      public object attribution { get; set; } 
     } 

     public class RootObject 
     { 
      public string name { get; set; } 
      public string permalink { get; set; } 
      public string crunchbase_url { get; set; } 
      public string homepage_url { get; set; } 
      public string blog_url { get; set; } 
      public string blog_feed_url { get; set; } 
      public string twitter_username { get; set; } 
      public string category_code { get; set; } 
      public int number_of_employees { get; set; } 
      public int founded_year { get; set; } 
      public int founded_month { get; set; } 
      public object founded_day { get; set; } 
      public object deadpooled_year { get; set; } 
      public object deadpooled_month { get; set; } 
      public object deadpooled_day { get; set; } 
      public object deadpooled_url { get; set; } 
      public string tag_list { get; set; } 
      public string alias_list { get; set; } 
      public string email_address { get; set; } 
      public string phone_number { get; set; } 
      public string description { get; set; } 
      public string created_at { get; set; } 
      public string updated_at { get; set; } 
      public string overview { get; set; } 
      public Image image { get; set; } 
      public List<object> products { get; set; } 
      public List<Relationship> relationships { get; set; } 
      public List<object> competitions { get; set; } 
      public List<Providership> providerships { get; set; } 
      public string total_money_raised { get; set; } 
      public List<FundingRound> funding_rounds { get; set; } 
      public List<object> investments { get; set; } 
      public object acquisition { get; set; } 
      public List<object> acquisitions { get; set; } 
      public List<Office> offices { get; set; } 
      public List<object> milestones { get; set; } 
      public object ipo { get; set; } 
      public List<VideoEmbed> video_embeds { get; set; } 
      public List<Screenshot> screenshots { get; set; } 
      public List<object> external_links { get; set; } 
     } 
    } 
} 
+1

呃,很难读。你可以缩短你的问题,只关注'我不知道该怎么做才能遍历从JSON端点返回的子对象。'什么是从终点返回的?你试过什么了? – 2012-01-18 22:10:23

回答

0

我猜你正在寻找这样的事情,如果不是你应该specifiy你的问题,或者说,为什么下面不工作或发生错误...

foreach (var office in j.offices) 
{ 
    Console.WriteLine("Description: {0}", office.description); 
    //... 
} 

但一个当然:可以用C#完成!

对于那些List<object>属性,您应该将相应的类添加到您的模型(您生成的类)或尝试将这些对象转换为JsonObject或某物。像那样。 (用VS查看实际类型。)

+0

这正是我想传达的!谢谢你的帮助,直到现在才回复给你(我是工作实习生 - 偶尔会让我远离pc)非常感谢!并欣赏额外的建议!你让我今天一整天都感觉很好! – 2012-01-19 05:37:13