标题: [文件操作] 【已解决】如何使用批处理进行批量提取文件并改名 [打印本页]
作者: 小天使 时间: 2021-1-23 21:03 标题: 【已解决】如何使用批处理进行批量提取文件并改名
求助一下如何使用批处理进行批量提取,例如在一个文件夹中有若干文件,需要提取的文件名在一个excel的第一列中,第二列为修改的名称,根据excel中第一列将指定文件复制并改名为第二列存放的新名称,放在一个新的文件夹。
作者: 路过 时间: 2021-1-23 21:46
用excel把xls转化成csv(【文件】——【导出】——【更改文件类型】——【CSV 逗号分隔……】)。
把要处理的文件和csv文件与批处理程序放在同一目录。- @echo off
- pushd "%~sdp0"
- setlocal enabledelayedexpansion
- set csvn=999.csv
- for /f "skip=1 delims=, tokens=1,*" %%a in (%csvn%) do (set .%%a=%%b)
- for %%a in (*) do (if defined .%%~na (
- if "%%a" neq "%csvn%" (if "%%a" neq "%~nx0" (
- copy "%%a" "D:\新的文件夹\!.%%~na!%%~xa"
- ))
- ))
- pause
- exit
复制代码
作者: 小天使 时间: 2021-1-23 23:30
回复 2# 路过
可以,感谢!
作者: qixiaobin0715 时间: 2021-1-24 09:47
本帖最后由 qixiaobin0715 于 2021-1-24 10:30 编辑
- @echo off
- md D:\newfolder
- for /f "skip=1 tokens=1,2 delims=," %%a in (999.csv) do copy "%%a.txt" "D:\newfolder\%%b.txt"
- pause
复制代码
作者: Batcher 时间: 2021-1-24 18:29
回复 2# 路过
在一个for循环里面直接处理就行了,没有必要先set以便吧。
欢迎光临 批处理之家 (http://www.bathome.net/) |
Powered by Discuz! 7.2 |