找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 21398|回复: 2

[文件操作] 批处理复制文件如何检查是否有任意excel文件打开?

[复制链接]
发表于 2021-7-7 14:15:35 | 显示全部楼层 |阅读模式
请教,若复制一个指定文件,到指定目录下,若存在,强制复盖。
如:复制:D:\测试组\项目A\重点项目.xls
        到:Y:\数据共享\生产中心\生产一部\重点项目.xls
若目标文件已存在,则复盖。

复制前,需做出一个判断,检查是否有任意excel文件打开(或检查EXCEL.EXE进程是否存在)
若无,则直接进行复制操作。
若有,则弹窗提示(有是/否按个按钮)
  发现有excel文件打开,是否强制关闭。
按:是(Y),强制关闭所有Excel文件,然后进行复制操作。
按:否(N),退出程序。


谢谢!
发表于 2021-7-7 19:54:30 | 显示全部楼层
本帖最后由 idwma 于 2021-7-7 20:02 编辑

<!-- ::
@echo off&setlocal enabledelayedexpansion
set "d=Y:\数据共享\生产中心\生产一部\重点项目.xls"
set "s=D:\测试组\项目A\重点项目.xls"
(tasklist /fi "imagename eq excel.exe" |find /i "excel.exe" >nul) && (for /f "delims=" %%i in ('mshta.exe "%~f0"') do set "f=%%i") || copy /y "%s%" "%d%"
if "!f!" == "1" taskkill /f /fi "imagename eq excel.exe" && copy /y "%s%" "%d%"
pause
goto :EOF
-->
<TITLE>发现有excel文件打开,是否强制关闭</TITLE>
<SCRIPT language="JavaScript">
window.resizeTo(550,110);
function closeHTA(reply){
var fso = new ActiveXObject("Scripting.FileSystemObject");
fso.GetStandardStream(1).WriteLine(reply);
window.close();
}
</SCRIPT>
<button onclick="closeHTA(1);">是(Y),强制关闭所有Excel文件,然后进行复制操作。</button>
<button onclick="closeHTA(2);">否(N),退出程序。</button>

评分

参与人数 1技术 +1 收起 理由
opelwang + 1 技法娴熟!

查看全部评分

 楼主| 发表于 2021-7-8 08:14:29 | 显示全部楼层
回复 2# idwma


   牛逼Plus,感谢!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-20 20:27 , Processed in 0.031175 second(s), 18 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表