Board logo

标题: [文件操作] 批处理改名多一个文件 [打印本页]

作者: 木易    时间: 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命令
  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

回复 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://bbs.bathome.net/) Powered by Discuz! 7.2