[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文件操作] 【已解决】如何使用批处理进行批量提取文件并改名

求助一下如何使用批处理进行批量提取,例如在一个文件夹中有若干文件,需要提取的文件名在一个excel的第一列中,第二列为修改的名称,根据excel中第一列将指定文件复制并改名为第二列存放的新名称,放在一个新的文件夹。
啦啦啦

用excel把xls转化成csv(【文件】——【导出】——【更改文件类型】——【CSV 逗号分隔……】)。
把要处理的文件和csv文件与批处理程序放在同一目录。
  1. @echo off
  2. pushd "%~sdp0"
  3. setlocal enabledelayedexpansion
  4. set csvn=999.csv
  5. for /f "skip=1 delims=, tokens=1,*" %%a in (%csvn%) do (set .%%a=%%b)
  6. for %%a in (*) do (if defined .%%~na (
  7.     if "%%a" neq "%csvn%" (if "%%a" neq "%~nx0" (
  8.         copy "%%a" "D:\新的文件夹\!.%%~na!%%~xa"
  9.     ))
  10. ))
  11. pause
  12. exit
复制代码

TOP

回复 2# 路过
可以,感谢!
啦啦啦

TOP

本帖最后由 qixiaobin0715 于 2021-1-24 10:30 编辑
  1. @echo off
  2. md D:\newfolder
  3. for /f "skip=1 tokens=1,2 delims=," %%a in (999.csv) do copy "%%a.txt" "D:\newfolder\%%b.txt"
  4. pause
复制代码

TOP

回复 2# 路过


    在一个for循环里面直接处理就行了,没有必要先set以便吧。
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

返回列表