我可以创建一个哈希数组:
people = [
{"Name" => "J.R. Kruger", "State" => "WA"},
{"Name" => "Carl Hennings", "State" => "CA"}
]
然后我可以使用以下each
语句:
people.each { |p| puts p["Name"] }
它将按照我的预期呈现一个名称列表。
"J.R. Kruger"
"Carl Hennings"
但是,如果我使用 JSON 对象的 Web 服务,这些对象会被解析为哈希数组:
speakers = JSON.parse(open("http://some.url.com/speakers.json").read)
它返回给我一个哈希数组。但是,如果我尝试做与上述代表人的哈希数组相同的事情:
speakers.each {|s| puts s["SpeakerName"]}
它只会输出扬声器的全部内容,这是一个哈希数组,而不是数组中"SpeakerName"
每个哈希的键值的预期列表。
我应该补充一点,我可以做到:
speakers[0]["SpeakerName"]
并获得所需的结果,以确保它不是错误的键。
缺少什么?
更新:
文件输出:
[
{
"Title"=>"Working with Maps in iOS 6: MapKit and CoreLocation in Depth",
"Abstract"=>"Adding a Map to an App and recording a User\u2019s location as they use the App has become a common must have feature in may of todays popular applications. This presentation will go over the updated iOS 6 APIs for accomplishing such tasks including map annotations, dragging and dropping custom pins as well as delve into some of the finer aspects of the required location based calculations one needs to consider to find the center of the map or the distance between two points. Additionally the presentation will go over techniques to update a MapView with a moving object as well as positioning the image for the object properly along its heading. This will be a straight forward hands on development presentation with plenty of code examples.",
"Start"=>"2013-01-11T20:35:00Z",
"Room"=>"Salon A",
"Difficulty"=>"Intermediate",
"SpeakerName"=>"Geoffrey Goetz",
"Technology"=>"Mac/iPhone",
"URI"=>"/api/sessions.json/Working-with-Maps-in-iOS-6-MapKit-and-CoreLocation-in-Depth",
"EventType"=>"Session",
"Id"=>"4f248d87-0e18-488d-8cef-5e4130b8bb20",
"SessionLookupId"=>"Working-with-Maps-in-iOS-6-MapKit-and-CoreLocation-in-Depth",
"SpeakerURI"=>"/api/speakers.json/Geoffrey-Goetz"
},
{
"Title"=>"Vendor Sessions - Friday",
"Start"=>"2013-01-11T20:00:00Z",
"End"=>"2013-01-11T20:20:00Z",
"Room"=>"TBD",
"Difficulty"=>"Beginner",
"SpeakerName"=>"All Attendees",
"Technology"=>"Other",
"URI"=>"/api/sessions.json/Vendor-Sessions--Friday",
"EventType"=>"Session",
"Id"=>"43720cb8-d8ca-4694-8806-debcbdefa239",
"SessionLookupId"=>"Vendor-Sessions--Friday",
"SpeakerURI"=>"/api/speakers.json/All-Attendees"
},
{
"Title"=>"Vendor Sessions - Thursday",
"Start"=>"2013-01-10T20:00:00Z",
"End"=>"2013-01-10T20:20:00Z",
"Room"=>"TBD",
"Difficulty"=>"Beginner",
"SpeakerName"=>"All Attendees",
"Technology"=>"Other",
"URI"=>"/api/sessions.json/Vendor-Sessions--Thursday",
"EventType"=>"Session",
"Id"=>"2df202e4-219c-4efb-a838-3898d183dd19",
"SessionLookupId"=>"Vendor-Sessions--Thursday",
"SpeakerURI"=>"/api/speakers.json/All-Attendees"
},
{
"Title"=>"Version your database on nearly any platform with Liquibase",
"Abstract"=>"If you are still writing one-off scripts to manage your database, then it is time to make your life much simpler and less error-prone. \nWe'll spend the time discussing Liquibase, a tool that will help you to manage that process. It will even allow you to check your schema and seed data into source-control, and get new environments up and running quickly. This session will focus not on the merits of using such a tool, but on its workflow and implementation in a project. We'll run through the majority of features from the command-line, demonstrating that as long as a Java Runtime Environment (jre) is available, Liquibase can be used during deployments on any platform. We'll also touch on usage with maven and quirks of Liquibase that are good to know ahead of time.",
"Start"=>"2013-01-11T20:35:00Z",
"Room"=>"Sagewood/Zebrawood",
"Difficulty"=>"Beginner",
"SpeakerName"=>"Daniel Bower",
"Technology"=>"Continuous Deployment",
"URI"=>"/api/sessions.json/Version-your-database-on-nearly-any-platform-with-Liquibase",
"EventType"=>"Session",
"Id"=>"4abb3869-bacd-42e1-93dc-14e712090b65",
"SessionLookupId"=>"Version-your-database-on-nearly-any-platform-with-Liquibase",
"SpeakerURI"=>"/api/speakers.json/Daniel-Bower"
}
]