返回列表 发帖
本帖最后由 dreamer 于 2024-6-10 16:01 编辑

回复 28# 77七
剛誤解您的意思了,改用call 就能回傳值
ps.顯示上只能看到"新",要看到"舊"需要加pause,不過a是由舊賦值也可證先跑舊再跑新
@echo off
if "%1" equ "" (
title
set a=a
call "%~f0" ###
) else (
title
set b=b
)
echo %a%
echo %b%
pauseCOPY
start "" "%0"

"%0"
都是另開線程,call跑同一線程,所以可以取得下層(新開窗)變數.
以15樓例來說,跑到start 就沒if的事了,它接著執行echo a,b 所以舊只會有a
以上面的例子來說if 還要等call做完事才會去echo a,b 所以會有a,b

TOP

回复 30# dreamer


   好几层楼都在讨论,新开的窗口的变量不能回传。虽然问题已经解决,我觉得是个特例,因为 在执行 C2R-R2V-AIO.cmd 中,以下判断均失败的原因,直接到了 set 这一行。
set "_cmdf=%~f0"
if exist "%SystemRoot%\Sysnative\cmd.exe" if not defined _rel1 (
setlocal EnableDelayedExpansion
start %SystemRoot%\Sysnative\cmd.exe /c ""!_cmdf!" -wow "
exit /b
)
if exist "%SystemRoot%\SysArm32\cmd.exe" if /i %PROCESSOR_ARCHITECTURE%==AMD64 if not defined _rel2 (
setlocal EnableDelayedExpansion
start %SystemRoot%\SysArm32\cmd.exe /c ""!_cmdf!" -arm "
exit /b
)
set "SysPath=%SystemRoot%\System32"COPY


特例中没有新开窗口,所有得到了期望的结果。
还有一点我觉得需要注意第136行 已经重定向了 call的子函数的输出,如果脚本不加改动,并且由136行执行子函数, for /f 是不会读取到这部分的。或者从 log文件能不能找到执行的结果呢?
@call :Begin >"!_log!_tmp.log"COPY



如果想让脚本更加通用,可以尝试13楼方法,并采用上此次回帖中,for /f +多次endlocal 带出变量,或者直接 改善C2R-R2V-AIO.cmd 脚本,多处setlocal 缺少endlocal 的情况,使其配对,然后使用预处理方式带出变量。
bat小白,请多指教!谢谢!

TOP

按13楼方法修改,试试能不能用,已上传到网盘。https://f.ws59.cn/f/ebmzeuacj08 复制链接到浏览器打开
bat小白,请多指教!谢谢!

TOP

回复 33# 77七
經測試確實可能,感謝幫大忙.

TOP

返回列表