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

[文件操作] 批处理改名多一个文件

[复制链接]
发表于 2021-11-16 10:05:15 | 显示全部楼层 |阅读模式
现有一个excel,文件名为“固定电话”,现在是点击一个批处理,复制这个文件并把文件名改为“当前日期+固定电话每日备份”,现在这个通过下面批处理可以实现,但新建出来文件后还回多一个文件,这是为什么,如果文件名是英文或是数字正常,(批处理文件编码由utf-8改为ansi),如果不修改都是乱码。



copy 固定电话.xlsx 固定电话每日备份.xlsx

@echo off
set fileName=%date:~0,4%%date:~5,2%%date:~8,2%

ren 固定电话每日备份.xlsx %fileName%固定电话每日备份.xlsx
发表于 2021-11-16 10:21:56 | 显示全部楼层
回复 1# 木易


    多的那个文件叫什么名字?
 楼主| 发表于 2021-11-16 10:42:36 | 显示全部楼层
回复 2# Batcher


    多出来文件名是乱码,0kb的文件:    1춨μ绰ÿèÕ±¸·Y.xlsx
发表于 2021-11-16 11:10:58 | 显示全部楼层
回复 1# 木易


    请把你的bat文件和Excel文件上传到阿里云盘或百度网盘,我试试。
 楼主| 发表于 2021-11-16 11:16:33 | 显示全部楼层
是这条批处理出现的问题

copy 固定电话.xlsx 固定电话每日备份.xlsx
发表于 2021-11-16 13:37:23 | 显示全部楼层
回复 1# 木易


直接copy的时候可以指定新文件名,不需要ren命令
  1. @echo off
  2. set "fileName=%date:~0,4%%date:~5,2%%date:~8,2%"
  3. copy "固定电话.xlsx" "%fileName%固定电话每日备份.xlsx"
复制代码
 楼主| 发表于 2021-11-16 13:47:04 | 显示全部楼层
回复 6# Batcher


    谢谢,问题解决了,直接copy的时候可以指定新文件名,不需要ren命令,还是会出现一个0kb的乱码文件,出问题的环节是copy的时候不能使用中文,重命名的时候可以。用下面这个代码就不会出现乱码文件。

copy bak.xlsx bak2.xlsx

@echo off
set fileName=%date:~0,4%%date:~5,2%%date:~8,2%

ren bak2.xlsx %fileName%固定电话每日备份.xlsx
发表于 2021-11-16 13:58:59 | 显示全部楼层
回复 3# 木易


从这个报错信息来看,还是你的BAT文件编码格式不对。

请参考Q-04把bat文件保存为ANSI编码:
https://mp.weixin.qq.com/s/6lbb97qUOs1sTyKJfN0ZEQ
发表于 2021-11-16 13:59:32 | 显示全部楼层
回复 7# 木易


    copy命令本身不存在这个限制,应该还是你的环境问题。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-3-21 00:20 , Processed in 0.029559 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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