【发布时间】:2018-09-11 16:05:01
【问题描述】:
我有一个名为 USER_PREM_HOL_AMT.bat 的文件。
里面的代码是:
set datename=%date% %username% %~n0
:CheckOS
IF EXIST "C:\Program Files\Microsoft Office\Office14\EXCEL.exe" (GOTO OFFICE2010) ELSE (GOTO OFFICE2013)
:OFFICE2010
ECHO %datename%>>"O:\Holiday.log"
START "" "C:\Program Files\Microsoft Office\Office14\EXCEL.exe" /e "file://///Log_files\Holiday.xlsm"
EXIT
GOTO END
这目前给出了日志:
Tue 09/11/2018 7098703 USER_PREM_HOL_AMT
我要它给我
Tue 09/11/2018 7098703 Holiday.xlsm
有没有办法做到这一点? 获取它打开的文件名而不是它自己的名字。
【问题讨论】:
-
我希望它记录它打开的文件的名称,而不是批处理文件自己的名称..!!
-
您可以使用
START "" "C:\Log_files\Holiday.xlsm",命令START会自动找出使用哪个应用程序打开文件扩展名为.xlsm的文件。 Where is “START” searching for executables? 解释了这是如何工作的。如果安装了 Microsoft Excel,也可以使用START "" Excel.exe "C:\Log_files\Holiday.xlsm"强制使用 Microsoft Excel 打开 *.xlsm 文件。 -
您知道
/被解释为\,它是目录分隔符,因此两个斜杠不能在文件名中使用吗?请参阅Naming Files, Paths, and Namespaces 了解有关 Windows 文件系统的基础知识。
标签: windows batch-file cmd batch-processing