标题: [文件操作] 批处理改名多一个文件 [打印本页]
作者: 木易 时间: 2021-11-16 10:05 标题: 批处理改名多一个文件
现有一个excel,文件名为“固定电话”,现在是点击一个批处理,复制这个文件并把文件名改为“当前日期+固定电话每日备份”,现在这个通过下面批处理可以实现,但新建出来文件后还回多一个文件,这是为什么,如果文件名是英文或是数字正常,(批处理文件编码由utf-8改为ansi),如果不修改都是乱码。
copy 固定电话.xlsx 固定电话每日备份.xlsx
@echo off
set fileName=%date:~0,4%%date:~5,2%%date:~8,2%
ren 固定电话每日备份.xlsx %fileName%固定电话每日备份.xlsx
作者: Batcher 时间: 2021-11-16 10:21
回复 1# 木易
多的那个文件叫什么名字?
作者: 木易 时间: 2021-11-16 10:42
回复 2# Batcher
多出来文件名是乱码,0kb的文件: 1춨μ绰ÿèÕ±¸·Y.xlsx
作者: Batcher 时间: 2021-11-16 11:10
回复 1# 木易
请把你的bat文件和Excel文件上传到阿里云盘或百度网盘,我试试。
作者: 木易 时间: 2021-11-16 11:16
是这条批处理出现的问题
copy 固定电话.xlsx 固定电话每日备份.xlsx
作者: Batcher 时间: 2021-11-16 13:37
回复 1# 木易
直接copy的时候可以指定新文件名,不需要ren命令- @echo off
- set "fileName=%date:~0,4%%date:~5,2%%date:~8,2%"
- copy "固定电话.xlsx" "%fileName%固定电话每日备份.xlsx"
复制代码
作者: 木易 时间: 2021-11-16 13:47
回复 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
作者: Batcher 时间: 2021-11-16 13:58
回复 3# 木易
从这个报错信息来看,还是你的BAT文件编码格式不对。
请参考Q-04把bat文件保存为ANSI编码:
https://mp.weixin.qq.com/s/6lbb97qUOs1sTyKJfN0ZEQ
作者: Batcher 时间: 2021-11-16 13:59
回复 7# 木易
copy命令本身不存在这个限制,应该还是你的环境问题。
欢迎光临 批处理之家 (http://www.bathome.net/) |
Powered by Discuz! 7.2 |