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

[文件操作] [已解决]批处理如何读取EXCEL内容给指定目录下的pdf文件名加上?

[复制链接]
发表于 2024-10-23 21:50:56 | 显示全部楼层 |阅读模式
本帖最后由 liaoguinan 于 2024-10-24 20:32 编辑



如图读取EXCEL内容,给PDF文件加上对应的名称

评分

参与人数 1PB +2 收起 理由
Batcher + 2 感谢给帖子标题标注[已解决]字样

查看全部评分

发表于 2024-10-24 12:18:48 | 显示全部楼层
  1. #@&cls&powershell "type '%~0'|out-string|iex"&pause&exit
  2. $fn='aaaaaa.xlsx'
  3. $fd='d:\测试测试\*.pdf'
  4. $a=new-object -com excel.application
  5. $b=$a.workbooks.open("$(dir $fn)")
  6. $c=$b.sheets.item(1)
  7. $d=$c.usedrange.cells.value()
  8. $a.quit()
  9. $i=$d.length
  10. $e=@{}
  11. 1..$i|%{$e[($d[$_,1] -split '-| ')[1]]=$d[$_,1]}
  12. dir $fd|%{
  13. $f=$e[[string][int]$_.basename]
  14. if($f){ren $_ ($f+$_.Extension)}
  15. }
复制代码

评分

参与人数 1技术 +1 收起 理由
Batcher + 1 乐于助人

查看全部评分

发表于 2024-10-24 17:15:12 | 显示全部楼层
本帖最后由 aloha20200628 于 2024-10-24 17:19 编辑

回复 1# liaoguinan

先调用excel外部接口将*.xls*电子表格文件转为*.csv文本文件,然后就是批处自己的功夫了...免去了用vba在电子表格里反复折腾...
以下代码存为 test.bat 其中第2-3行中的目标文件和路径均由楼主自定义...

  1. @set @x=1 /* &@echo off &setlocal
  2. set "xF=d:\测试\测试.xls"
  3. set "pD=d:\测试"
  4. cscript /e:jscript "%~f0" "%xF%"
  5. for /f "usebackq delims=" %%F in ("%xF%.csv") do for /f "tokens=2 delims=- " %%a in ("%%F") do (
  6.     setlocal enabledelayedexpansion &set "a=00%%a" &set "a=!a:~-3!"
  7.     if exist "%pD%\!a!.pdf" ren "%pD%\!a!.pdf" "%%F.pdf"
  8.     endlocal
  9. )
  10. del/q "%xF%.csv"&endlocal&pause&exit/b */
  11. v=WSH.arguments, xls=WSH.createobject('excel.application');
  12. xls.visible=false, xls.displayalerts=false, wb=xls.workbooks.open(v(0));
  13. wb.saveas(v(0)+'.csv',6), wb.close(), xls.quit(), WSH.quit();
复制代码
 楼主| 发表于 2024-10-24 20:32:30 | 显示全部楼层
回复 2# idwma


    完美
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-17 18:20 , Processed in 0.018721 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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