我正在尝试处理一个 JSON 对象,使用 guard 语句将其解包并转换为我想要的类型,但该值仍被保存为可选值。
guard let json = try? JSONSerialization.jsonObject(with: data) as? [String:Any] else {
break
}
let result = json["Result"]
// Error: Value of optional type '[String:Any]?' not unwrapped
我是不是漏掉了什么?
最佳答案
try? JSONSerialization.jsonObject(with: data) as? [String:Any]
被解释为
try? (JSONSerialization.jsonObject(with: data) as? [String:Any])
这使它成为 [String:Any]?? 类型的“双重可选”??。
可选绑定(bind)只删除一层,因此 json 具有
类型 [String:Any]?
问题通过设置括号解决:
guard let json = (try? JSONSerialization.jsonObject(with: data)) as? [String:Any] else {
break
}
只是为了好玩:另一个(不太明显?,混淆?)解决方案是 使用带有双重可选模式的模式匹配:
guard case let json?? = try? JSONSerialization.jsonObject(with: data) as? [String:Any] else {
break
}
关于swift - 守卫不展开可选,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43123036/
我在下面有一个步骤定义,它执行我想要它执行的操作,即它根据“PAGES”哈希的“page”元素检查页面的url。Then(/^Ishould(still)?beatthe"(.*)"page$/)do|still,page|BROWSER.url.should==PAGES[page]end步骤定义用于两者我应该在...页面我应该还在...页面但是,我不需要将“still”传递到block中。我只需要它是可选的以匹配步骤但不传递到block中。我该怎么做?谢谢。 最佳答案 您想将“静止”组标记为非捕获。这是通过使用?:启动组来完成的
如果我在Ruby中有以下方法:deffoo(arg1,arg2="bar")putsarg1putsarg2end有没有办法确定用户是否在方法中为arg2传递了一个值?显然,我可以将ifarg2=="bar"添加到方法中,但这并没有捕捉到用户自己手动传入"bar"的情况。当然,我可以将默认值设置为任何用户都不会传入的内容,但这样很快就会变得非常丑陋。那里有什么优雅的东西吗? 最佳答案 deffoo(arg1,arg2=(arg2_not_passed=true;"bar"))putsarg1putsarg2puts'arg2wasp
有没有办法制作一个简单的守卫watch?我想在特定目录中的文件更改时运行rake任务,并且完成所有这些步骤对于这个一次性任务来说太多了。https://github.com/guard/guard/wiki/Create-a-guard我尝试将它添加到Guardfile中,但它不起作用。guard:docdowatch(%r{^documentation}){"rakedoc:build"}endwatch("/documentation"){"rakedoc:build"}那么当文件更新为guard时,您是否知道一种运行rake任务的简单方法?? 最佳答案
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭9年前。Improvethisquestion我目前正在使用guard来监视我的.coffee和.scss文件的变化并适本地编译它们。现在,gruntjs和yeoman提供了类似的功能。从guard转向gruntjs或yeoman的动机是什么?使用yeoman和gruntjs有什么好处,反之亦然?谢谢!
我有一个这样记录的函数:###Searchesforstreetnamesinthelocaladdressdatabase.Returnsalist#ofstrings,orinvokestheblockforeachresult.##@param[String,Hash]query##Canbe:##-Asearchstringwithoptinalwildcards.Examples:#-"Bærumsv*"#-"Fornebuve_en"##@param[Integer]limit##Limitstheamountofresults.See{#search_street_add
我正在尝试动态定义调用另一个采用选项参数的函数的函数:classMyClass["hour","minute","second"].eachdo|interval|define_method"get_#{interval}"do|args|some_helper(interval,args)endenddefsome_helper(interval,options={})#Dosomething,withargumentsendend我希望能够以这两种方式调用MyClass的不同方法(有和没有可选参数):mc=MyClass.newmc.get_minute(:first_option
我如何向rubygems添加可选依赖项,因为它不支持它?用例:我有一个依赖于Backports、Extlib、Facets或ActiveSupport的库。在过去,我只是没有添加任何依赖项,因为人们可以选择(阅读:它可以很好地与他们使用的任何东西一起使用),但是人们提示很多库不能开箱即用,或者他们会相信它取决于ActiveSupport(在某些情况下对某些人来说是不行的)。所以目前它依赖于Backports,因为它是最小的。尽管这意味着人们会在安装我的库时安装Backports,即使他们可能不会在运行时使用它。我想根据环境依赖不同的gem(例如MRI/Rubinius上的Johns
我有一个带有可选参数的方法。我如何确定是否给出了Argument?我想出了以下解决方案。我问这个问题是因为我对其中任何一个都不完全满意。还有更好的吗?nil作为默认值defm(a=nil)ifa.nil?...endend这个的缺点是,无法确定是没有参数还是nil被给出。自定义NoArgument作为默认值classNoArgumentenddefm(a=NoArgument.new)ifNoArgument===a...endend是否给定nil是可以判断的,但是NoArgument的实例也存在同样的问题。评估省略号的大小defm(*a)raiseArgumentErrorifm.s
假设我有一个像这样的proc/lambda/block/method/etc:2.1.2:075>procedure=Proc.new{|a,b=2,*c,&d|42}=>#我知道我可以通过以下方式找出参数的名称:2.1.2:080>procedure.parameters=>[[:opt,:a],[:opt,:b],[:rest,:c],[:block,:d]]但是,如果给定的可选参数未给定,我该如何获取该可选参数的值呢?附言:是的。我知道这在here之前已经被问过/回答过,但之前的解决方案需要使用merbgem,这实际上有点误导。merb本身依赖于methoparagem(除非您使
给定一个类,classMyClassdefindex(arg1,arg2="hello")endend是否可以通过Class#instance_method等方法获取arg2的默认值? 最佳答案 似乎我们可以检查方法参数值的唯一方法是访问方法的binding。使用Tracepoint类,我们可以获取这样一个绑定(bind)对象,然后检查所有optional参数的值。我们需要确保只使用必需的参数调用所需的方法,以便为默认参数分配默认值。下面是我尝试这样做的-它适用于实例方法和类方法。为了调用实例方法,我们需要实例化类-如果构造函数需要