- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Python 中,可以使用 *
运算符来解包可迭代对象。
In [1]: head, *tail = [1, 2, 3, 4, 5]
In [2]: head
Out[2]: 1
In [3]: tail
Out[3]: [2, 3, 4, 5]
我想在 Julia 中产生相同的行为。我认为等效的 ...
运算符可以工作,但它似乎只是在这种情况下产生错误。
julia> head, tail... = [1, 2, 3, 4, 5]
ERROR: syntax: invalid assignment location "tail..."
我能够使用以下方法产生我想要的结果,但这是一个丑陋的解决方案。
julia> head, tail = A[1], A[2:end]
(1,[2,3,4,5])
我能否使用 splat (...
) 运算符解压数组,使 tail
包含 head
之后的其余项目?如果不是,最干净的替代品是什么?
编辑: 此功能已在 #2626 中提出.看起来它将成为 1.0 版本的一部分。
最佳答案
It is now possible to use
...
on the left-hand side of destructured assignments for taking any number of items from the front of an iterable collection, while also collecting the rest.
分配前两项而忽略其余项的示例:
julia> a, b, c... = [4, 8, 15, 16, 23, 42]
# 6-element Vector{Int64}:
# 4
# 8
# 15
# 16
# 23
# 42
julia> a
# 4
julia> b
# 8
julia> c
# 4-element Vector{Int64}:
# 15
# 16
# 23
# 42
This syntax is implemented using
Base.rest
, which can be overloaded to customize its behavior.
重载示例 Base.rest(s::Union{String, SubString{String}}, i::Int)
使用 Vector{Char}
而不是默认的 SubString
:
julia> a, b... = "hello"
julia> b
# "ello"
julia> Base.rest(s::Union{String, SubString{String}}, i=1) = collect(SubString(s, i))
julia> a, b... = "hello"
julia> b
# 4-element Vector{Char}:
# 'e': ASCII/Unicode U+0065 (category Ll: Letter, lowercase)
# 'l': ASCII/Unicode U+006C (category Ll: Letter, lowercase)
# 'l': ASCII/Unicode U+006C (category Ll: Letter, lowercase)
# 'o': ASCII/Unicode U+006F (category Ll: Letter, lowercase)
关于Julia splat 运算符拆包,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42335661/
如何覆盖解包语法*obj和**obj的结果? 例如,您能否以某种方式创建一个行为如下的对象 thing: >>> [*thing] ['a', 'b', 'c'] >>> [x for x in th
在 Python 中,可以使用 * 运算符来解包可迭代对象。 In [1]: head, *tail = [1, 2, 3, 4, 5] In [2]: head Out[2]: 1 In [3]:
我被要求调整我前一段时间正在处理的脚本。我得到了帮助here .在脚本中,我使用了 splatting 和格式运算符。它在脚本上进一步工作,但失败了。我打开了一个小得多的样本来显示失败。如果您需要查看
我大部分时间都在用这个。我试图在 splatting 之前向我的哈希表添加一个参数。但是,我尝试添加的参数是两个字符串的集合。 $myHT = @{ From = 'me@x.
F# 内置运算符/函数是否允许解包参数列表/元组并将其传递给函数调用? 用法示例: // simple add function let add (a1 : int) (a2 : int) (a3 :
我正在尝试使用 Start-Job 来启动一个新的 Powershell 脚本。新脚本有几个参数(有些是可选的,有些不是),所以我想制作一个哈希表并将它们拼凑起来。然而,这些参数之一本身就是一个哈希表
下面的 Split-Path 参数不正确,它应该是 $delZipExe。 这使得 $delZipCmd 哈希值被设置为空。 我希望 WorkingDirectory 值在 $delZipCmd 哈希
我试图解压一个列表: ls = [1, 2, 3] a, *b = ls 然后,我尝试解压字典: dc = {'x': 1, 'y': 2, 'z': 3} a, **b = dc # Out: Sy
我在一篇文章中看到了这方面的插图,但是当我在我的 IRB shell 中尝试它时,我得到了一个错误。以下代码合法吗?否则有没有一种简写的方法来获取中间数组(比如假定排序数组的 1 或 2 个元素的中值
对于下面的方法 def mixed_args(a,b,*c,d) puts a,b,c,d end p mixed_args(1,2,3,4,5) 我收到此错误消息: syntax error,
为什么这段代码 Hash[*[[:first_name, 'Shane'], [:last_name, 'Harvie']].flatten] 返回这个 {:first_name=>"Shane",
使用yield_self,一元方法的参数可以预先放置在方法链中。因此,给定: Foo = Struct.new(:one_arg) 这一行: Foo.new("x") 相当于那一行: "x".yiel
我是 Ruby 的新手,将构建国际象棋作为一种学习练习。我正在尝试重构一些代码,但遇到了困难。 为什么这样做: @available_moves = [] #part of castling logi
match, text, number = *"foobar 123".match(/([A-z]*) ([0-9]*)/) 我知道这是在做某种正则表达式匹配,但是 splat 在这里扮演什么角色,有
def initialize(apps, catch=404) @apps = []; @has_app = {} apps.each { |app| add app } @catch =
昨天有人问splat运算符,我想看源代码……是用C写的还是Ruby写的?在哪里可以找到? 最佳答案 一些快速的谷歌搜索显示它是在 eval.c 中实现的。 .您可以在文件中的几个地方找到对“splat
散列上的 splat 将其转换为数组。 [*{foo: :bar}] # => [[:foo, :bar]] 这里是否存在某种隐藏机制(例如隐式类转换),或者它是一种内置的原始特征? 除了数组,nil
我在浏览 Camping 代码库时看到一个带有 splat 的构造函数,如下所示: class Fruit def initialize(*) end end 我试着在这个网站和谷歌上查找“s
这是我的程序: def calculate(*numbers, options = {}) add(numbers) if options[:add] subtract(number
我定义了一个带有循环的模块: module "stamp" { for_each = toset(var.stamps) source = "./modules/stamp" ...
我是一名优秀的程序员,十分优秀!