2015-05-11 7 views

Antwort

3

Noch nicht, aber Sie können sich selbst helfen, wenn Sie möchten.

import Base.getindex, Base.setindex! 
    const .. = Val{:...} 

    setindex!{T}(A::AbstractArray{T,1}, x, ::Type{Val{:...}}, n) = A[n] = x 
    setindex!{T}(A::AbstractArray{T,2}, x, ::Type{Val{:...}}, n) = A[ :, n] = x 
    setindex!{T}(A::AbstractArray{T,3}, x, ::Type{Val{:...}}, n) = A[ :, :, n] =x 

    getindex{T}(A::AbstractArray{T,1}, ::Type{Val{:...}}, n) = A[n] 
    getindex{T}(A::AbstractArray{T,2}, ::Type{Val{:...}}, n) = A[ :, n] 
    getindex{T}(A::AbstractArray{T,3}, ::Type{Val{:...}}, n) = A[ :, :, n] 

Dann können Sie

> rand(3,3,3)[.., 1] 
    3x3 Array{Float64,2}: 
    0.0750793 0.490528 0.273044 
    0.470398 0.461376 0.01372 
    0.311559 0.879684 0.531157 

schreiben Wenn Sie aufwändigere Slicing möchten, müssen Sie erstellen/erweitern die Definition bzw. Funktionen in Szene gesetzt.

+1

und es gibt mehr Diskussion (inc von Ihnen) auf der GitHub-Frage: https://github.com/JuliaLang/julia/issues/5405 – paddyg

Verwandte Themen