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

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

[复制链接]
发表于 2021-1-23 21:03:43 | 显示全部楼层 |阅读模式
求助一下如何使用批处理进行批量提取,例如在一个文件夹中有若干文件,需要提取的文件名在一个excel的第一列中,第二列为修改的名称,根据excel中第一列将指定文件复制并改名为第二列存放的新名称,放在一个新的文件夹。
发表于 2021-1-23 21:46:51 | 显示全部楼层
用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:43 | 显示全部楼层
回复 2# 路过
可以,感谢!
发表于 2021-1-24 09:47:12 | 显示全部楼层
本帖最后由 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
复制代码
发表于 2021-1-24 18:29:09 | 显示全部楼层
回复 2# 路过


    在一个for循环里面直接处理就行了,没有必要先set以便吧。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-20 21:47 , Processed in 0.031805 second(s), 17 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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