Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialwachter
1,594 PointsUnexpectedly found nil while unwrapping an optional value
This is the code I'm using and for some reason the console displays the title of this post.
private let apiKey = ""//32 letters and numbers
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
let baseURL = NSURL(string: "https://api.forecast.io/forecast/\(apiKey)")
let forecastURL = NSURL(string: "37.8267,-122.423", relativeToURL : baseURL)
let sharedSession = NSURLSession.sharedSession()
let downloadTask : NSURLSessionDownloadTask = sharedSession.downloadTaskWithURL(forecastURL!, completionHandler: { (location: NSURL!, response: NSURLResponse!, error: NSError!) -> Void in
if (error == nil) {
let dataObject = NSData(contentsOfURL: location)
let weatherDictionary : NSDictionary = NSJSONSerialization.JSONObjectWithData(
dataObject!, options: nil, error: nil) as! NSDictionary
println(weatherDictionary)
}
})
downloadTask.resume()
}
The error seems to come from the weatherDictionary. Thanks for any help.
2 Answers
Caleb Kleveter
Treehouse Moderator 37,862 PointsI believe you are supposed to us an "if-let" statement instead of a !.
Caleb Kleveter
Treehouse Moderator 37,862 PointsI'm not sure, I'm new to Swift.
wachter
1,594 Pointswachter
1,594 Pointshow would I go about changing it to "if let" the correct way? When I tried it told me the data type was not convertible or something.