Julia 中的字典元素操作

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)

Col*_*ers 7

为字典的键和值定义了迭代协议,因此您可以这样做,例如:

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.