2017-04-11 109 views
1

我正在尝试使用IntegerVector{Integer}子集值的组合在Julia中对Vector{String}进行子集化。我想编写一个函数,基本上允许的"asdf"[1:3]与三个参数x[y:z]的子集是任何载体或单身。在Julia中使用向量来处理字符串向量中的元素

这是我迄今为止尝试:

function substring(x::Array{String}, y::Integer, z::Integer) 
    y = fill(y, length(x)) 
    z = fill(z, length(x)) 
    substring(x, y, z) 
end 

function substring(x::Vector{String}, y::Vector{Integer}, z::Integer) 
    y = fill(y, length(x)) 
    substring(x, y, z) 
end 

function substring(x::Vector{String}, y::Integer, z::Vector{Integer}) 
    z = fill(z, length(x)) 
    substring(x, y, z) 
end 

function substring(x::Vector{String}, y::Vector{Integer}, z::Vector{Integer}) 
    for i = 1:length(x) 
    x[i] = x[i][y[i]:min(z[i], length(x[i]))] 
    # If z[i] is greater than the length of x[i] 
    # return the end of the string 
    end 
    x 
end 

尝试使用它:

v = string.('a':'z') 
x = rand(v, 100) .* rand(v, 100) .* rand(v, 100) 

substring(x, 1, 2) 
# or 
substring(x, 1, s) 

我得到的错误:

MethodError: no method matching substring(::Array{String,1}, ::Int64, ::Array{Int64,1}) 
Closest candidates are: 
    substring(::Array{String,N}, ::Integer, !Matched::Integer) at untitled-e3b9271a972031e628a35deeeb23c4a8:2 
    substring(::Array{String,1}, ::Integer, !Matched::Array{Integer,1}) at untitled-e3b9271a972031e628a35deeeb23c4a8:13 
    substring(::Array{String,N}, ::Integer, !Matched::Array{Integer,N}) at untitled-e3b9271a972031e628a35deeeb23c4a8:13 
    ... 
in include_string(::String, ::String, ::Int64) at eval.jl:28 
in include_string(::Module, ::String, ::String, ::Int64, ::Vararg{Int64,N}) at eval.jl:32 
in (::Atom.##53#56{String,Int64,String})() at eval.jl:50 
in withpath(::Atom.##53#56{String,Int64,String}, ::Void) at utils.jl:30 
in withpath(::Function, ::String) at eval.jl:38 
in macro expansion at eval.jl:49 [inlined] 
in (::Atom.##52#55{Dict{String,Any}})() at task.jl:60 

我看到有另一个post addressingVector{String}类似的错误。我的帖子还回应了与Vector{Integer}相关的错误。我相信对它的回应可能有助于像我这样的人发现抽象类型的实现新颖和困难。

+2

的可能的复制[向量{AbstractString}函数参数将不接受在朱向量{字符串}输入](http://stackoverflow.com/questions/21465838/vectorabstractstring-function-parameter-wont-accept-vectorstring- input-in-j) –

+2

这是一个参数不变性的例子。见http://stackoverflow.com/questions/21465838/vectorabstractstring-function-parameter-wont-accept-vectorstring-input-in-j对于s类似的问题;这里你的问题在'Vector {Integer}'中。 –

+0

我想指出,虽然我的问题已被解释为类型管理问题。我真的只是在寻找一个符合标题所说的功能。在我更习惯的R中,答案是微不足道的,'substr(x,1,2)'。我列出了上面的代码,以表明我已经做出了合理的努力来自己解决这个问题。如果没有太多的麻烦,我会非常感谢答案。 – fsmart

回答

3

如果你在朱莉娅0.6,这是很容易用做SubString.(strs, starts, ends)

julia> SubString.("asdf", 2, 3) 
"sd" 

julia> SubString.(["asdf", "cdef"], 2, 3) 
2-element Array{SubString{String},1}: 
"sd" 
"de" 

julia> SubString.("asdf", 2, [3, 4]) 
2-element Array{SubString{String},1}: 
"sd" 
"sdf" 

在朱莉娅0.5,你可以做同样的事情,但是,必须用一个向量的字符串(即它不能被保留为一个标):

julia> SubString.(["asdf"], [1, 2, 3], [2, 3, 4]) 
3-element Array{SubString{String},1}: 
"as" 
"sd" 
"df" 

朱莉娅和R之间的主要区别是,而在R,职能通常由默认的矢量工作(广播),在朱莉娅你明确地使用所谓的“点叫”,即指定广播行为f.(x, y, z)

1

只是为了显式的认为它是一个超级普通的事情去思考。

即使Int64 <: Integer是真的

Array{Int64,1} <: Array{Integer,1}是不是!


docs on parametric-composite-types解释的细节。但套用其基本上是因为前者Array{Int64,1}在存储器中的特定表示(即许多个连续的64位值),而Array{Integer,1}必须是套指针到单独分配的值,其可以是或可以不是64位。

看到类似Q &一种很酷的新语法,你可以使用在茱莉亚0.6声明函数W /考虑到这一点:Vector{AbstractString} function parameter won't accept Vector{String} input in julia

+0

你介意告诉我你将如何改变代码来使其工作? – fsmart

相关问题