Board logo

标题: [文件操作] 【已解决】如何使用批处理进行批量提取文件并改名 [打印本页]

作者: 小天使    时间: 2021-1-23 21:03     标题: 【已解决】如何使用批处理进行批量提取文件并改名

求助一下如何使用批处理进行批量提取,例如在一个文件夹中有若干文件,需要提取的文件名在一个excel的第一列中,第二列为修改的名称,根据excel中第一列将指定文件复制并改名为第二列存放的新名称,放在一个新的文件夹。
作者: 路过    时间: 2021-1-23 21:46

用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
复制代码

作者: 小天使    时间: 2021-1-23 23:30

回复 2# 路过
可以,感谢!
作者: qixiaobin0715    时间: 2021-1-24 09:47

本帖最后由 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
复制代码

作者: Batcher    时间: 2021-1-24 18:29

回复 2# 路过


    在一个for循环里面直接处理就行了,没有必要先set以便吧。




欢迎光临 批处理之家 (http://www.bathome.net/) Powered by Discuz! 7.2