0

我正在尝试编写一个看起来像这样的流:

def perform(id) do
  id
  |> Flow.from_stage(max_demand: 10)
  |> Flow.map(&download(&1))
  |> Flow.map(&process(&1))
  |> Flow.each(&cleanup(&1, &2))
  |> Flow.each(&respond(&1, &2))
  |> Flow.run
end

模块中的其他函数如下所示:

def download(id) do
  Service.get_images(id)
  id
end

def process(id) do
  %Result{out: sys_out, status: _} = Porcelain.exec("osascript",
    ["#{File.cwd!}/lib/script/test", "#{id}", "#{Application.get_env(:app, :server_env)}"]
  )
  {id, sys_out}
end

def cleanup(id, files) do
  for file <- String.split(files, " ") do
    System.cmd("exiftool", ["#{File.cwd!}/#{file}"])
  end
  {id, files}
end

def respond(id, files) do
  files = String.split(files, " ")
  System.cmd("curl", [" -d 'dowhatever=#{files[0]}&else=#{files[1]}' -k #{Application.get_env(:app, :api)}what/#{id}/notify"])
  :ok
end

但我不断收到此错误:

** (FunctionClauseError) no function clause matching in Flow.each/2
...
(app) lib/app/processor.ex:18: App.Processor.perform/1

第 18 行是该&cleanup/2行。我在这里做错了什么?感觉就像我没有以某种方式返回正确的值......

4

1 回答 1

2

process/1返回一个 tuple {id, sys_out},whilecleanup/2被声明有一个2

迭代元组列表意味着迭代器必须是 arity 1。你应该在里面 cleanup/1分解你的元组:

- def cleanup(id, files) do
+ def cleanup({id, files}) do

并称之为:

Flow.each(&cleanup/1)

这同样适用于随后的respond.

于 2017-10-17T07:32:14.687 回答