Bre*_*ung 3 dictionary julia elementwise-operations
我想向字典的所有值广播一个操作。对于数组,我知道我可以使用以下方法广播元素操作:
julia> b1 = [1, 2, 3]
julia> b1./2
3-element Array{Float64,1}:
0.5
1.0
1.5
Run Code Online (Sandbox Code Playgroud)
将相同操作广播到字典的所有值的有效方法是什么?说,为了字典
a1 = Dict("A"=>1, "B"=>2)
Run Code Online (Sandbox Code Playgroud)
为字典的键和值定义了迭代协议,因此您可以这样做,例如:
julia> d = Dict("a"=>1, "b"=>2)
Dict{String,Int64} with 2 entries:
"b" => 2
"a" => 1
julia> values(d).^2
2-element Array{Int64,1}:
4
1
Run Code Online (Sandbox Code Playgroud)
如果您想就地更改字典,请使用map!
,例如:
julia> map!(x->x^2, values(d))
Base.ValueIterator for a Dict{String,Int64} with 2 entries. Values:
4
1
julia> d
Dict{String,Int64} with 2 entries:
"b" => 4
"a" => 1
Run Code Online (Sandbox Code Playgroud)
但是,您的函数必须输出可以转换回字典值类型的类型。在我的示例中,我正在平方Int
其中产生Int
. 但是,在问题中,您除以 2,这显然会产生Float64
。如果浮点数无法转换回整数,则会出现错误。
请注意,您也可以通过键进行广播,例如:
julia> f(x) = "hello mr $(x)"
f (generic function with 1 method)
julia> f.(keys(d))
2-element Array{String,1}:
"hello mr b"
"hello mr a"
Run Code Online (Sandbox Code Playgroud)
但这不能就地完成,即您不能map!
在键上使用。
重要的是,请注意,您应该不实例化集合。确实,这将是低效的。所以要避免像这样的结构:collect(values(d)) ./ 2
.