Lua - popen 2x '&&' 链式 set /p - stdout 休假了。 (注:该语句为一段代码,其中包含Lua语言中的popen、2x '&&' chained、set /p等命令和指令,具体含义需要结合上下文理解。)

我在一个完全没有 UI 的环境下工作,当运行 Lua 脚本时。这对我要编写的脚本来说是不可接受的,因为它严重依赖于用户输入。我发现绕过这个问题的唯一方法是使用 io.popen 和一些相当巧妙的命令。

我知道我在这里尝试做的事情很奇怪,非常错误,而我也是自找的,但我无法弄清楚这段代码片段出了什么问题:

local a = 'f'
local p = io.popen(
    'echo      -~`~-,_,- Editing '..(a == 'f' and 'foreground' or 'background')..' -~`~-,_,- > con && '.. --显示文本给用户
    'set /p f= Find block: > con < con && '.. --用户输入
    'call echo %f% &&' .. --将 f 传回 lua 脚本
    'set /p r= Replace with: > con < con && '.. --用户输入
    'call echo %r% &&' .. --将 r 传回 lua 脚本
    'pause < con', "r")
local f = p:read("*a") --读取传回的内容,并稍后将其解析回 2 个变量
p:close()

我期望发生的事情:

  1. 显示一个“命令提示符窗口”向用户询问输入。
  2. 用户输入 2 个值。
  3. 输入时将值作为它们输入。
  4. 从管道中读取并存储这些值以供稍后使用。
  5. 命令行等待按键,然后关闭。

实际上发生的事情:

  1. 显示一个“命令提示符窗口”向用户询问输入。
  2. 用户为 f 输入了一个值。
  3. f 被返回到 lua 脚本。
  4. 用户为 r 输入了一个值。
  5. r 被回送到控制台。(!!!)
  6. 从管道读取 fr 没有出现。
  7. 命令行等待按键,然后关闭。

这个非常相似的代码示例很好用,但只返回一个变量:

p = io.popen(
    'echo What do you want to do? > con && '..
    'echo G: remove girders > con && '..
    'echo F: swap foreground > con && '..
    'echo B: swap background > con && '..
    'echo U: undo all edits > con && '..
    'echo C: cancel > con && '..
    'set /p a= Choose an option: > con < con && '..
    'call echo %a%', "r")
a = string.lower(p:read("*a"):gsub("\n",""))
p:close()

我做错了什么,如何重写以适应我的目的? 我到底 unlea 了什么,如何把这个鬼塞回去?

点赞
用户1847592
用户1847592
local p = io.popen(
   -- 创建临时 .bat 文件
   'set tmpf="%TEMP%\\TMP%RANDOM%.BAT" &&'..
   'cmd /c"(echo @set p=^%1&echo @set /p x= ^%p:~1,-1^%^>con&echo @call echo ^%x^%)>%tmpf%" &&'..
   -- 主程序
   'echo.      -~`~-,_,- 正在编辑'..(a == 'f' and '前景' or '背景')..' -~`~-,_,- > con &&'.. -- 将文本显示给用户
   'call %tmpf% "查找块:" < con &&'..  -- 将 f 传回 Lua 脚本
   'call %tmpf% "替换为:" < con &&'..-- 将 r 传回 Lua 脚本
   -- 删除临时 .bat 文件
   'call del %tmpf% > con &&'..
   'pause < con', "r")
local f = p:read'*a'
p:close()
2015-06-26 16:55:53
用户4109488
用户4109488

经过一番谷歌搜索,我找到了这个:

(
 echo some output
 echo more output
)>"Your logfile

从批处理文件中重定向输出

我不知道你可以像这样包装命令,而且自从我第一次发现Windows CLI以来,我一直在 tinkering。


local a = 'f'
local p = io.popen(
    'echo      -~`~-,_,- Editing '..(a == 'f' and 'foreground' or 'background')..' -~`~-,_,- > con && '.. --向用户显示文本
    '( set /p f= Find block: && '.. --用户输入
    'set /p r= Replace with: ) > con < con && '.. --用户输入
    'call echo %f% &&' .. --将f传回lua脚本
    'call echo %r% &&' .. --将r传回lua脚本
    'pause < con > con', "r")
local f = p:read("*a") --读取传回的内容,稍后将其解析回两个变量
p:close()

像上面这样包装两个set /p声明可以工作-我得到了预期的f输出,然后是一个换行符,然后是r,所有内容都被发送回lua脚本,正如它们所属的那样。

尽管如此,如果有人能告诉我为什么这一开始是个问题,我会非常感兴趣。

2015-06-28 04:58:44